- 浏览: 334406 次
- 性别:
- 来自: 沈阳
文章分类
最新评论
-
znfsky:
找了好一会,原来要手动加链接库,赞一个
codeblocks处理undefined reference to `pthread_create' -
qiankai86:
Thank you!
java平均分配算法 -
yl419440513:
表名称和列名称中文乱码怎么解决呢
ResultSet 对象getTables()的用法 获取表的相关信息 -
sumaolin:
写的挺详细的啊
html marque元素标签属性的参数说明 -
brown802:
我都加过这个包啦,还是有错误
Unable to find parent packages json-default
一、 Oracle表分区的概念
Oracle 分区功能可以提高许多应用程序的可管理性、性能与可用性。通过分区功能,可以将表、索引和索引组织表进一步细分为段,从而能够更精确地管理和访问这些数据库对象。Oracle 提供了种类繁多的分区方案以满足每种业务要求。
而且,因为在 SQL 语句中分区是完全透明的,所以该功能几乎可应用于任何应用程序。
分区功能的优势
分区功能通过改善可管理性、性能和可用性,从而为各式应用程序带来了极大的好处。通常,分区可以使某些查询以及维护操作的性能大大提高。此外,分区还可以极大简化常见的管理任务。通过分区,数据库设计人员和管理员能够解决前沿应用程序带来的一些难题。分区是构建千兆字节数据系统或超高可用性系统的关键工具。
分区功能的基本知识
分区功能能够将表、索引或索引组织表进一步细分为段。这些数据库对象的段叫做分区。每个分区有自己的名称,还可以选择自己的存储特性。从数据库管理员的角度来看,一个分区后的对象具有多个段,这些段既可进行集体管理,也可单独管理。这就使数据库管理员在管理分区后的对象时有相当大的灵活性。但是,从应用程序的角度来看,分区后的表与非分区表完全相同,使用 SQL DML 命令访问分区后的表时,无需任何修改。
表的分区是通过“分区键”来实现的,分区键指的是一些列,这些列决定了某一行所在的分区。Oracle 数据库 10g 提供了六项技术用于对表进行分区:
范围分区
每个分区都由一个分区键值范围指定(对于一个以日期列作为分区键的表,“2005 年 1 月”分区包含分区键值为从“2005 年 1 月 1 日”到“2005 年 1 月 31 日”的行)。
列表分区
每个分区都由一个分区键值列表指定(对于一个地区列作为分区键的表,“北美”分区可能包含值“加拿大”“美国”和“墨西哥”)。
散列分区
将散列算法用于分区键来确定指定行所在的分区。
组合范围散列分区
范围和散列分区技术的组合,通过该组合,首先对表进行范围分区,然后针对每个单独的范围分区再使用散列分区技术进一步细分。索引组织表只能进行范围分区。
组合范围列表分区
范围和列表分区技术的组合,通过该组合,首先对表进行范围分区,然后针对每个单独的范围分区再使用列表分区技术进一步细分。索引组织表可以按范围、列表或散列进行分区。
Oracle 数据库 10g 还提供了三种类型的分区索引:
本地索引
本地索引是其分区方式与其所在基础表的分区方式一模一样的索引。本地索引的每个分区仅对应于其所在基础表的一个分区。
全局分区索引
全局分区索引是使用不同于其所在表的分区键进行分区的索引,其所在表可以是分区表或非分区表。全局分区的索引可以使用范围或散列分区进行分区。例如,某个表可以按月份进行范围分区,因此具有十二个分区,而该表上的索引则可以使用不同的分区键进行范围分区,从而具有不同的分区数量。
全局非分区索引
全局非分区索引基本上和非分区表的索引一样。索引结构是不分区的。
Oracle 提供了一系列丰富的技术,可用于对表、索引和索引组织表进行分区,因此可以针对任何业务环境中的任何应用程序进行最佳的分区 Oracle 还提供一套完整的 SQL 命令,用于管理分区表。其中包括添加新分区、删除分区、分拆分区以及合并分区的命令。
用分区功能提高可管理性
通过 Oracle 分区功能,可将表和索引分成更多、更小的可管理单元,从而使数据库管理员能以“化整为零,个个击破”的方式管理数据。
使用分区功能,维护操作可集中于表的特定部分。例如,数据库管理员可以只对表的一部分做备份,而不必对整个表做备份。对整个数据库对象的维护操作,可以在每个分区的基础上进行,从而将维护工作分解成更容易管理的小块。
利用分区功能提高可管理性的一个典型用法是支持数据仓库中的‘滚动视窗’加载进程。假设数据库管理员每周向表中加载新数据。可以对该表进行范围分区,使每个分区包含一周的数据。这样加载进程只是简单地添加新的分区。添加一个分区的操作比修改整个表效率高很多,因为 DBA 不需要修改任何其他分区。
用分区功能提高性能
由于限制了所检查或操作的数据数量,同时支持并行任务执行,Oracle 分区功能实现了性能上增益。这些特性包括:
分区修整
分区修整是用分区功能提高性能的最简单最有价值的手段。分区修整常常能够将查询性能提高几个数量级。例如,假设某个应用程序包含一个存储订单历史记录的 Orders 表,并且此表已按周分区。查询一周的订单只需访问该订单表的一个分区。如果该订单表包含两年的历史记录,这个查询只需要访问一个分区而不是一百零四个。该查询的执行速度因为分区修整而有可能快一百倍。分区修整能与所有其他 Oracle 性能特性协作。Oracle 能将分区修整功能与任何索引技术、联接技术或并行访问方法结合使用。
分区智能联接
分区功能可以通过称为分区智能联接的技术提高多表联接的性能。当两个表要联接在一起,而且每个表都用联接键来分区时,就可以使用分区智能联接。分区智能联接将大型联接分解成较小的发生在各个分区间的联接,从而用较少的时间完成全部联接。这就给串行和并行的执行都能带来显著的性能改善。
用分区功能提高可用性
分区的数据库对象具有分区独立性。该分区独立性特点可能是高可用性战略的一个重要部分,例如,如果分区表的一个分区不能用,但该表的所有其他分区仍然保持在线并可用。那么这个应用可以继续针对该分区表执行查询和事务处理,只要不是访问不可用的分区,数据库操作仍然能够成功运行。
数据库管理员可以指定各分区存放在不同的表空间里,从而让管理员隔离其它表分区针对单个分区进行备份与恢复操作。还有,分区功能可以减少计划停机时间。由于分区功能改善了性能,使数据库管理员能用相对较少的时间完成大型数据库对象的维护工作。
未来发展方向
自从引入分区技术以来,Oracle 公司在每次推出重要版本时都会增加新的分区方法。Oracle8 引入了范围分区功能,Oracle8i 引入了散列和组合范围散列分区功能,Oracle9i 引入了列表分区功能。在最新版本 Oracle 数据库 10g 中,则增强了用于索引组织表和全局分区索引的分区策略,并且扩展了其用于所有分区维护操作的并发索引维护功能。Oracle 公司致力于不断完善分区技术,确保满足所有的业务需求。
结论
具有 Oracle 分区功能的 Oracle 数据库 10g 可以显著增强几乎任何数据库应用程序的可管理性、性能和可用性。分区功能可用于前沿应用程序,分区功能确实能够成为保障这些应用程序成功的关键技术成分。同时,分区功能也可用于较为普通的数据库应用,来简化这些应用的管理工作,降低管理成本。
二、Oracle表分区的类型
1)范围分区
范围分区就是对数据表中的某个值的范围进行分区,根据某个值的范围,决定将该数据存储在哪个分区上。如根据 序号分区,根据业务记录的创建日期进行分区等。
2)哈希分区
散列分区为通过指定分区编号来均匀分布数据的一种分区类型,因为通过在I/O设备上进行散列分区,使得这些分区大小一致。如将物料交易表的数据根据交易 ID散列地存放在指定的三个表空间中。
3)列表分区
当你需要明确地控制如何将行映射到分区时,就使用列表分区方法。可以在每个分区的描述中为该分区列指定一列离散值,这不同于范围分区,在那里一个范 围与一个分区相关,这也不同于散列分区,在那里用户不能控制如何将行映射到分区。列表分区方法是特意为遵从离散值的模块化数据划分而设计的。范围分区或散 列分区不那么容易做到这一点。进一步说列表分区可以非常自然地将无序的和不相关的数据集进行分组和组织到一起。
与范围分区和散列分区所不同,列表分区不支持多列分区。如果要将表按列分区,那么分区键就只能由表的一个单独的列组成,然而可以用范围分区或散列分 区方法进行分区的所有的列,都可以用列表分区方法进行分区。
4)组合分区
有时候我们需要根据范围分区后,每个分区内的数据再散列地分布在几个表空间中,这样我们就要使用复合分区。复合分区是先使用范围分区,然后在每个分区内再 使用散列分区的一种分区方法,如将物料交易的记录按时间分区,然后每个分区中的数据分三个子分区,将数据散列地存储在三个指定的表空间中。
三、Oracle表分区的实际操作
--查看s数据文件信息
select * from dba_data_files;
--查看用户表空间信息
select * from user_tablespaces;
--这里创建三个表空间,并建立相应的数据文件
create tablespace xgtest_space01 datafile 'D:\ORACLE\ORADATA\ORCL\xg_partition01.DBF' size 50M;
create tablespace xgtest_space02 datafile 'D:\ORACLE\ORADATA\ORCL\xg_partition02.DBF' size 50M;
create tablespace xgtest_space03 datafile 'D:\ORACLE\ORADATA\ORCL\xg_partition03.DBF' size 50M;
1) 范围分区实例
--创建一个产品表,这个表一产品表主键作为范围分区字段,
--设置小于100000的产品主键记录放到product_p01分区表,100000-500000的记录放在product_p02分区,大于500000放到product_p03分区
create table test_product(
product_id number(11) primary key,
product_name varchar2(64) not null,
created_date date not null,
company_name varchar2(128)
)
partition by range (product_id)(
partition product_p01 values less than(100000) tablespace xgtest_space01,
partition product_p02 values less than(500000) tablespace xgtest_space02,
partition product_p03 values less than(maxvalue) tablespace xgtest_space03
);
--查询建立的产品表信息
select * from user_tables t where t.table_name = upper('test_product');
--查询建立的产品表信息
select * from user_part_tables t where t.table_name = upper('test_product');
--查询建立的产品表的分区信息
select * from user_tab_partitions t where t.table_name = upper('test_product');
--插入几条产品表信息并做事务提交
insert into test_product values(100,'IBM便携式电脑T43',sysdate,'IBM');
insert into test_product values(1000,'佳能A720相机',sysdate,'Canon');
insert into test_product values(105000,'联想X200',sysdate,'联想');
insert into test_product values(300000,'Iphone4',sysdate,'Apple');
insert into test_product values(700000,'windows7系列',sysdate,'microsoft');
commit;
--查询每个分区的分表记录信息
select * from test_product partition(product_p01);
select * from test_product partition(product_p02);
select * from test_product partition(product_p03);
--查询表信息
select * from test_product;
--分区表条件查询
select * from test_product partition(product_p01) t where t.product_id = 1000;
--表条件查询
select * from test_product t where t.product_id = 1000;
--在分区表上做更新操作
update test_product partition(product_p01) t set t.company_name='佳能公司' where t.product_id=1000;
commit;
--在分区表上做删除操作
delete from test_product partition(product_p01) t where t.product_id=300000;
commit;
2) 哈希分区实例
--建立一个销售订单记录表,并按照销售时间做哈希分区字段
create table test_sale_order(
sale_order_id number(11) primary key,
product_name varchar2(64) not null,
saled_date date not null,
operator_name varchar2(32)
)
partition by hash(saled_date)(
partition sale_order_p01 tablespace xgtest_space01,
partition sale_order_p02 tablespace xgtest_space02,
partition sale_order_p03 tablespace xgtest_space03
);
--查询表信息以及分区信息
select * from user_part_tables t where t.table_name = upper('test_sale_order');
select * from user_tab_partitions t where t.table_name = upper('test_sale_order');
--插入销售订单记录
insert into test_sale_order values(1000, '罗技鼠标',to_date('2007-06-23','yyyy-mm-dd'),'许果');
insert into test_sale_order values(1001, 'Thinkpad T60笔记本',to_date('2007-06-23','yyyy-mm-dd'),'fruitking');
insert into test_sale_order values(1002, '海尔冰箱',to_date('2008-06-20','yyyy-mm-dd'),'刘德华');
insert into test_sale_order values(1003, '格力空调',to_date('2007-10-09','yyyy-mm-dd'),'刘若英');
insert into test_sale_order values(1004, '浪莎丝袜',to_date('2009-09-05','yyyy-mm-dd'),'孙俪');
insert into test_sale_order values(1005, '美的电扇',to_date('2010-03-19','yyyy-mm-dd'),'小张');
insert into test_sale_order values(1006, '安琪儿自行车',to_date('2015-07-28','yyyy-mm-dd'),'小林');
commit;
--查询分区记录以及表记录,分区和表的条件查询
select * from test_sale_order partition(sale_order_p01);
select * from test_sale_order partition(sale_order_p02);
select * from test_sale_order partition(sale_order_p03);
select * from test_sale_order;
select * from test_sale_order partition(sale_order_p01) t where t.sale_order_id = 1000;
select * from test_sale_order t where t.sale_order_id = 1000;
3) 列表分区实例
--创建公司表,并已列表分区
create table test_company(
company_id number(11) primary key,
company_name varchar2(64) not null,
created_date date not null,
city_name varchar2(32)
)
partition by list (city_name)(
partition company_p01 values ('杭州') tablespace xgtest_space01,
partition company_p02 values ('上海') tablespace xgtest_space02,
partition company_p03 values (default) tablespace xgtest_space03
);
--查询表和分区信息
select * from user_part_tables t where t.table_name = upper('test_company');
select * from user_tab_partitions t where t.table_name = upper('test_company');
--插入公司记录信息
insert into test_company values(1000, '阿里巴巴',sysdate,'杭州');
insert into test_company values(1001, '华为',sysdate,'深圳');
insert into test_company values(1002, '恒生电子',sysdate,'杭州');
insert into test_company values(1003, '盛大',sysdate,'上海');
insert into test_company values(1004, '浦发银行',sysdate,'上海');
insert into test_company values(1005, '信雅达',sysdate,'杭州');
insert into test_company values(1006, '富shi康',sysdate,'深圳');
insert into test_company values(1007, '东风汽车',sysdate,'武汉');
commit;
--查询分区记录,表记录,分区和表的条件查询
select * from test_company partition(company_p01);
select * from test_company partition(company_p02);
select * from test_company partition(company_p03);
select * from test_company;
select * from test_company partition(company_p01) t where t.company_id = 1000;
select * from test_company t where t.company_id = 1000;
4) 复合分区实例
--创建一个话单表,并已组合分区(先范围分区,再哈希分区的方式)
create table test_phone_order(
phone_order_id number(11) primary key,
phone_no varchar2(64) not null,
consumed_date date not null,
consumed_address varchar2(32)
)
partition by range(consumed_date)subpartition by hash(phone_order_id)
subpartitions 3 store in (xgtest_space01,xgtest_space02,xgtest_space03)(
partition phone_order_p01 values less than(to_date('2006-01-01','yyyy-mm-dd')),
partition phone_order_p02 values less than(to_date('2010-01-01','yyyy-mm-dd')),
partition phone_order_p03 values less than(maxvalue)
);
--查看表信息和分区信息
select * from user_part_tables t where t.table_name = upper('test_phone_order');
select * from user_tab_partitions t where t.table_name = upper('test_phone_order');
--插入话单记录
insert into test_phone_order values(1000, '13588879410',to_date('2001-06-23','yyyy-mm-dd'),'杭州');
insert into test_phone_order values(1001, '13588879411',to_date('2007-06-23','yyyy-mm-dd'),'南昌');
insert into test_phone_order values(1002, '13588879412',to_date('2004-06-20','yyyy-mm-dd'),'成都');
insert into test_phone_order values(1003, '13588879413',to_date('2025-10-09','yyyy-mm-dd'),'重庆');
insert into test_phone_order values(1004, '13588879414',to_date('2009-09-05','yyyy-mm-dd'),'北京');
insert into test_phone_order values(1005, '13588879415',to_date('2010-03-19','yyyy-mm-dd'),'南京');
insert into test_phone_order values(1006, '13588879416',to_date('2015-07-28','yyyy-mm-dd'),'苏州');
commit;
--查看话单的分区记录和表记录,分区和表的条件查询
select * from test_phone_order partition(phone_order_p01);
select * from test_phone_order partition(phone_order_p02);
select * from test_phone_order partition(phone_order_p03);
select * from test_phone_order;
select * from test_phone_order partition(phone_order_p01) t where t.phone_order_id = 1000;
select * from test_phone_order t where t.phone_order_id = 1000;
四)Oracle表分区对应用系统程序开发的影响和优化策略
1)JDBC的增删改操作
增删改这样的信息一般可以直接在表上操作,而不必指定特定的分区,在实际应用中,增删改的操作都是部分的,而且是小数据量的
2)JDBC的查询操作
查询操作,一般如果明确知道一个查询范围,我们可以指定到某个分区去查询,这样提高查询效率,如果不知道在哪个分区则直接使用表查询
3)JDBC应用策略
使用表分区主要是表的数据量非常大,一般应用中表的增删改操作比较少,查询次数多,而且花费时间长,故分区时,查询操作按照分区去查询更能提高查询速度
Oracle 分区功能可以提高许多应用程序的可管理性、性能与可用性。通过分区功能,可以将表、索引和索引组织表进一步细分为段,从而能够更精确地管理和访问这些数据库对象。Oracle 提供了种类繁多的分区方案以满足每种业务要求。
而且,因为在 SQL 语句中分区是完全透明的,所以该功能几乎可应用于任何应用程序。
分区功能的优势
分区功能通过改善可管理性、性能和可用性,从而为各式应用程序带来了极大的好处。通常,分区可以使某些查询以及维护操作的性能大大提高。此外,分区还可以极大简化常见的管理任务。通过分区,数据库设计人员和管理员能够解决前沿应用程序带来的一些难题。分区是构建千兆字节数据系统或超高可用性系统的关键工具。
分区功能的基本知识
分区功能能够将表、索引或索引组织表进一步细分为段。这些数据库对象的段叫做分区。每个分区有自己的名称,还可以选择自己的存储特性。从数据库管理员的角度来看,一个分区后的对象具有多个段,这些段既可进行集体管理,也可单独管理。这就使数据库管理员在管理分区后的对象时有相当大的灵活性。但是,从应用程序的角度来看,分区后的表与非分区表完全相同,使用 SQL DML 命令访问分区后的表时,无需任何修改。
表的分区是通过“分区键”来实现的,分区键指的是一些列,这些列决定了某一行所在的分区。Oracle 数据库 10g 提供了六项技术用于对表进行分区:
范围分区
每个分区都由一个分区键值范围指定(对于一个以日期列作为分区键的表,“2005 年 1 月”分区包含分区键值为从“2005 年 1 月 1 日”到“2005 年 1 月 31 日”的行)。
列表分区
每个分区都由一个分区键值列表指定(对于一个地区列作为分区键的表,“北美”分区可能包含值“加拿大”“美国”和“墨西哥”)。
散列分区
将散列算法用于分区键来确定指定行所在的分区。
组合范围散列分区
范围和散列分区技术的组合,通过该组合,首先对表进行范围分区,然后针对每个单独的范围分区再使用散列分区技术进一步细分。索引组织表只能进行范围分区。
组合范围列表分区
范围和列表分区技术的组合,通过该组合,首先对表进行范围分区,然后针对每个单独的范围分区再使用列表分区技术进一步细分。索引组织表可以按范围、列表或散列进行分区。
Oracle 数据库 10g 还提供了三种类型的分区索引:
本地索引
本地索引是其分区方式与其所在基础表的分区方式一模一样的索引。本地索引的每个分区仅对应于其所在基础表的一个分区。
全局分区索引
全局分区索引是使用不同于其所在表的分区键进行分区的索引,其所在表可以是分区表或非分区表。全局分区的索引可以使用范围或散列分区进行分区。例如,某个表可以按月份进行范围分区,因此具有十二个分区,而该表上的索引则可以使用不同的分区键进行范围分区,从而具有不同的分区数量。
全局非分区索引
全局非分区索引基本上和非分区表的索引一样。索引结构是不分区的。
Oracle 提供了一系列丰富的技术,可用于对表、索引和索引组织表进行分区,因此可以针对任何业务环境中的任何应用程序进行最佳的分区 Oracle 还提供一套完整的 SQL 命令,用于管理分区表。其中包括添加新分区、删除分区、分拆分区以及合并分区的命令。
用分区功能提高可管理性
通过 Oracle 分区功能,可将表和索引分成更多、更小的可管理单元,从而使数据库管理员能以“化整为零,个个击破”的方式管理数据。
使用分区功能,维护操作可集中于表的特定部分。例如,数据库管理员可以只对表的一部分做备份,而不必对整个表做备份。对整个数据库对象的维护操作,可以在每个分区的基础上进行,从而将维护工作分解成更容易管理的小块。
利用分区功能提高可管理性的一个典型用法是支持数据仓库中的‘滚动视窗’加载进程。假设数据库管理员每周向表中加载新数据。可以对该表进行范围分区,使每个分区包含一周的数据。这样加载进程只是简单地添加新的分区。添加一个分区的操作比修改整个表效率高很多,因为 DBA 不需要修改任何其他分区。
用分区功能提高性能
由于限制了所检查或操作的数据数量,同时支持并行任务执行,Oracle 分区功能实现了性能上增益。这些特性包括:
分区修整
分区修整是用分区功能提高性能的最简单最有价值的手段。分区修整常常能够将查询性能提高几个数量级。例如,假设某个应用程序包含一个存储订单历史记录的 Orders 表,并且此表已按周分区。查询一周的订单只需访问该订单表的一个分区。如果该订单表包含两年的历史记录,这个查询只需要访问一个分区而不是一百零四个。该查询的执行速度因为分区修整而有可能快一百倍。分区修整能与所有其他 Oracle 性能特性协作。Oracle 能将分区修整功能与任何索引技术、联接技术或并行访问方法结合使用。
分区智能联接
分区功能可以通过称为分区智能联接的技术提高多表联接的性能。当两个表要联接在一起,而且每个表都用联接键来分区时,就可以使用分区智能联接。分区智能联接将大型联接分解成较小的发生在各个分区间的联接,从而用较少的时间完成全部联接。这就给串行和并行的执行都能带来显著的性能改善。
用分区功能提高可用性
分区的数据库对象具有分区独立性。该分区独立性特点可能是高可用性战略的一个重要部分,例如,如果分区表的一个分区不能用,但该表的所有其他分区仍然保持在线并可用。那么这个应用可以继续针对该分区表执行查询和事务处理,只要不是访问不可用的分区,数据库操作仍然能够成功运行。
数据库管理员可以指定各分区存放在不同的表空间里,从而让管理员隔离其它表分区针对单个分区进行备份与恢复操作。还有,分区功能可以减少计划停机时间。由于分区功能改善了性能,使数据库管理员能用相对较少的时间完成大型数据库对象的维护工作。
未来发展方向
自从引入分区技术以来,Oracle 公司在每次推出重要版本时都会增加新的分区方法。Oracle8 引入了范围分区功能,Oracle8i 引入了散列和组合范围散列分区功能,Oracle9i 引入了列表分区功能。在最新版本 Oracle 数据库 10g 中,则增强了用于索引组织表和全局分区索引的分区策略,并且扩展了其用于所有分区维护操作的并发索引维护功能。Oracle 公司致力于不断完善分区技术,确保满足所有的业务需求。
结论
具有 Oracle 分区功能的 Oracle 数据库 10g 可以显著增强几乎任何数据库应用程序的可管理性、性能和可用性。分区功能可用于前沿应用程序,分区功能确实能够成为保障这些应用程序成功的关键技术成分。同时,分区功能也可用于较为普通的数据库应用,来简化这些应用的管理工作,降低管理成本。
二、Oracle表分区的类型
1)范围分区
范围分区就是对数据表中的某个值的范围进行分区,根据某个值的范围,决定将该数据存储在哪个分区上。如根据 序号分区,根据业务记录的创建日期进行分区等。
2)哈希分区
散列分区为通过指定分区编号来均匀分布数据的一种分区类型,因为通过在I/O设备上进行散列分区,使得这些分区大小一致。如将物料交易表的数据根据交易 ID散列地存放在指定的三个表空间中。
3)列表分区
当你需要明确地控制如何将行映射到分区时,就使用列表分区方法。可以在每个分区的描述中为该分区列指定一列离散值,这不同于范围分区,在那里一个范 围与一个分区相关,这也不同于散列分区,在那里用户不能控制如何将行映射到分区。列表分区方法是特意为遵从离散值的模块化数据划分而设计的。范围分区或散 列分区不那么容易做到这一点。进一步说列表分区可以非常自然地将无序的和不相关的数据集进行分组和组织到一起。
与范围分区和散列分区所不同,列表分区不支持多列分区。如果要将表按列分区,那么分区键就只能由表的一个单独的列组成,然而可以用范围分区或散列分 区方法进行分区的所有的列,都可以用列表分区方法进行分区。
4)组合分区
有时候我们需要根据范围分区后,每个分区内的数据再散列地分布在几个表空间中,这样我们就要使用复合分区。复合分区是先使用范围分区,然后在每个分区内再 使用散列分区的一种分区方法,如将物料交易的记录按时间分区,然后每个分区中的数据分三个子分区,将数据散列地存储在三个指定的表空间中。
三、Oracle表分区的实际操作
--查看s数据文件信息
select * from dba_data_files;
--查看用户表空间信息
select * from user_tablespaces;
--这里创建三个表空间,并建立相应的数据文件
create tablespace xgtest_space01 datafile 'D:\ORACLE\ORADATA\ORCL\xg_partition01.DBF' size 50M;
create tablespace xgtest_space02 datafile 'D:\ORACLE\ORADATA\ORCL\xg_partition02.DBF' size 50M;
create tablespace xgtest_space03 datafile 'D:\ORACLE\ORADATA\ORCL\xg_partition03.DBF' size 50M;
1) 范围分区实例
--创建一个产品表,这个表一产品表主键作为范围分区字段,
--设置小于100000的产品主键记录放到product_p01分区表,100000-500000的记录放在product_p02分区,大于500000放到product_p03分区
create table test_product(
product_id number(11) primary key,
product_name varchar2(64) not null,
created_date date not null,
company_name varchar2(128)
)
partition by range (product_id)(
partition product_p01 values less than(100000) tablespace xgtest_space01,
partition product_p02 values less than(500000) tablespace xgtest_space02,
partition product_p03 values less than(maxvalue) tablespace xgtest_space03
);
--查询建立的产品表信息
select * from user_tables t where t.table_name = upper('test_product');
--查询建立的产品表信息
select * from user_part_tables t where t.table_name = upper('test_product');
--查询建立的产品表的分区信息
select * from user_tab_partitions t where t.table_name = upper('test_product');
--插入几条产品表信息并做事务提交
insert into test_product values(100,'IBM便携式电脑T43',sysdate,'IBM');
insert into test_product values(1000,'佳能A720相机',sysdate,'Canon');
insert into test_product values(105000,'联想X200',sysdate,'联想');
insert into test_product values(300000,'Iphone4',sysdate,'Apple');
insert into test_product values(700000,'windows7系列',sysdate,'microsoft');
commit;
--查询每个分区的分表记录信息
select * from test_product partition(product_p01);
select * from test_product partition(product_p02);
select * from test_product partition(product_p03);
--查询表信息
select * from test_product;
--分区表条件查询
select * from test_product partition(product_p01) t where t.product_id = 1000;
--表条件查询
select * from test_product t where t.product_id = 1000;
--在分区表上做更新操作
update test_product partition(product_p01) t set t.company_name='佳能公司' where t.product_id=1000;
commit;
--在分区表上做删除操作
delete from test_product partition(product_p01) t where t.product_id=300000;
commit;
2) 哈希分区实例
--建立一个销售订单记录表,并按照销售时间做哈希分区字段
create table test_sale_order(
sale_order_id number(11) primary key,
product_name varchar2(64) not null,
saled_date date not null,
operator_name varchar2(32)
)
partition by hash(saled_date)(
partition sale_order_p01 tablespace xgtest_space01,
partition sale_order_p02 tablespace xgtest_space02,
partition sale_order_p03 tablespace xgtest_space03
);
--查询表信息以及分区信息
select * from user_part_tables t where t.table_name = upper('test_sale_order');
select * from user_tab_partitions t where t.table_name = upper('test_sale_order');
--插入销售订单记录
insert into test_sale_order values(1000, '罗技鼠标',to_date('2007-06-23','yyyy-mm-dd'),'许果');
insert into test_sale_order values(1001, 'Thinkpad T60笔记本',to_date('2007-06-23','yyyy-mm-dd'),'fruitking');
insert into test_sale_order values(1002, '海尔冰箱',to_date('2008-06-20','yyyy-mm-dd'),'刘德华');
insert into test_sale_order values(1003, '格力空调',to_date('2007-10-09','yyyy-mm-dd'),'刘若英');
insert into test_sale_order values(1004, '浪莎丝袜',to_date('2009-09-05','yyyy-mm-dd'),'孙俪');
insert into test_sale_order values(1005, '美的电扇',to_date('2010-03-19','yyyy-mm-dd'),'小张');
insert into test_sale_order values(1006, '安琪儿自行车',to_date('2015-07-28','yyyy-mm-dd'),'小林');
commit;
--查询分区记录以及表记录,分区和表的条件查询
select * from test_sale_order partition(sale_order_p01);
select * from test_sale_order partition(sale_order_p02);
select * from test_sale_order partition(sale_order_p03);
select * from test_sale_order;
select * from test_sale_order partition(sale_order_p01) t where t.sale_order_id = 1000;
select * from test_sale_order t where t.sale_order_id = 1000;
3) 列表分区实例
--创建公司表,并已列表分区
create table test_company(
company_id number(11) primary key,
company_name varchar2(64) not null,
created_date date not null,
city_name varchar2(32)
)
partition by list (city_name)(
partition company_p01 values ('杭州') tablespace xgtest_space01,
partition company_p02 values ('上海') tablespace xgtest_space02,
partition company_p03 values (default) tablespace xgtest_space03
);
--查询表和分区信息
select * from user_part_tables t where t.table_name = upper('test_company');
select * from user_tab_partitions t where t.table_name = upper('test_company');
--插入公司记录信息
insert into test_company values(1000, '阿里巴巴',sysdate,'杭州');
insert into test_company values(1001, '华为',sysdate,'深圳');
insert into test_company values(1002, '恒生电子',sysdate,'杭州');
insert into test_company values(1003, '盛大',sysdate,'上海');
insert into test_company values(1004, '浦发银行',sysdate,'上海');
insert into test_company values(1005, '信雅达',sysdate,'杭州');
insert into test_company values(1006, '富shi康',sysdate,'深圳');
insert into test_company values(1007, '东风汽车',sysdate,'武汉');
commit;
--查询分区记录,表记录,分区和表的条件查询
select * from test_company partition(company_p01);
select * from test_company partition(company_p02);
select * from test_company partition(company_p03);
select * from test_company;
select * from test_company partition(company_p01) t where t.company_id = 1000;
select * from test_company t where t.company_id = 1000;
4) 复合分区实例
--创建一个话单表,并已组合分区(先范围分区,再哈希分区的方式)
create table test_phone_order(
phone_order_id number(11) primary key,
phone_no varchar2(64) not null,
consumed_date date not null,
consumed_address varchar2(32)
)
partition by range(consumed_date)subpartition by hash(phone_order_id)
subpartitions 3 store in (xgtest_space01,xgtest_space02,xgtest_space03)(
partition phone_order_p01 values less than(to_date('2006-01-01','yyyy-mm-dd')),
partition phone_order_p02 values less than(to_date('2010-01-01','yyyy-mm-dd')),
partition phone_order_p03 values less than(maxvalue)
);
--查看表信息和分区信息
select * from user_part_tables t where t.table_name = upper('test_phone_order');
select * from user_tab_partitions t where t.table_name = upper('test_phone_order');
--插入话单记录
insert into test_phone_order values(1000, '13588879410',to_date('2001-06-23','yyyy-mm-dd'),'杭州');
insert into test_phone_order values(1001, '13588879411',to_date('2007-06-23','yyyy-mm-dd'),'南昌');
insert into test_phone_order values(1002, '13588879412',to_date('2004-06-20','yyyy-mm-dd'),'成都');
insert into test_phone_order values(1003, '13588879413',to_date('2025-10-09','yyyy-mm-dd'),'重庆');
insert into test_phone_order values(1004, '13588879414',to_date('2009-09-05','yyyy-mm-dd'),'北京');
insert into test_phone_order values(1005, '13588879415',to_date('2010-03-19','yyyy-mm-dd'),'南京');
insert into test_phone_order values(1006, '13588879416',to_date('2015-07-28','yyyy-mm-dd'),'苏州');
commit;
--查看话单的分区记录和表记录,分区和表的条件查询
select * from test_phone_order partition(phone_order_p01);
select * from test_phone_order partition(phone_order_p02);
select * from test_phone_order partition(phone_order_p03);
select * from test_phone_order;
select * from test_phone_order partition(phone_order_p01) t where t.phone_order_id = 1000;
select * from test_phone_order t where t.phone_order_id = 1000;
四)Oracle表分区对应用系统程序开发的影响和优化策略
1)JDBC的增删改操作
增删改这样的信息一般可以直接在表上操作,而不必指定特定的分区,在实际应用中,增删改的操作都是部分的,而且是小数据量的
2)JDBC的查询操作
查询操作,一般如果明确知道一个查询范围,我们可以指定到某个分区去查询,这样提高查询效率,如果不知道在哪个分区则直接使用表查询
3)JDBC应用策略
使用表分区主要是表的数据量非常大,一般应用中表的增删改操作比较少,查询次数多,而且花费时间长,故分区时,查询操作按照分区去查询更能提高查询速度
发表评论
-
oracle备份的bat文件
2010-04-15 12:39 1550rem call LogicBackup.bat %DUMP_ ... -
exp imp导出与导入
2010-01-19 14:47 1204Oracle数据导入导出imp/exp 功能:Oracle数 ... -
删除oracle的BAT文件
2009-12-26 15:02 1000@echo off&&setlocal e ... -
oracle数据库学习
2009-11-28 09:56 992char 定长的数据类型,最大能存储2000个字节,如果不选择 ... -
Oracle自动增长数据类型
2009-11-12 16:39 1292使用触发器。使用触发器 创建序列 create seque ... -
oracle优化内存,提高查询性能
2009-11-11 14:36 1658内存的优化历来都是数据库或者操作系统优化的重中之重。在Orac ... -
ORACLE 取前几条记录
2009-11-11 13:46 38321. 最佳选择:利用分析函数 row_number() ... -
oracle学习之查询
2009-11-10 15:52 879desc emp; 显示数据库表结构 select empn ... -
操作语句
2009-11-08 20:39 914建表语句 cretae table student( na ... -
卸载oracle9
2009-11-06 18:48 11341,停止oracle所有服务。 2,运行oracle univ ... -
数据库的基本概念
2009-11-05 18:52 901DB 数据库 DBMS 数据库管理系统 DBA 数据库管理员 ... -
使用存储过程读取Oracle中的clob字段的数据
2009-09-28 10:20 3273在做数据库开发的时候,有时候会遇到需要读取Oracle数据库中 ... -
oracle物化视图
2009-09-28 09:16 1678物化视图是一种特殊的 ... -
oracle授权一个表给另一个用户
2009-09-28 09:08 2888grant xxx权限 on TableA to USERA ...
相关推荐
- 分区表的管理可能比非分区表复杂,尤其是当涉及到大量分区时。 - 对于频繁更改分区键的场景,分区表的维护成本较高。 #### 四、分区类型及示例 ##### 1. 范围分区 范围分区是根据一个列的值的范围来决定数据存储...
### Oracle表分区、建表空间与用户管理 #### 一、表空间的创建与管理 在Oracle数据库中,**表空间**(Tablespace)是物理存储的逻辑容器,它由一个或多个数据文件组成。创建一个新的表空间对于数据库的管理非常重要...
在实际应用中,还需要关注分区表的索引、物化视图、分区维护操作(如添加、合并和拆分分区)等方面,以确保系统性能和可维护性。 总结来说,Oracle表分区是大型数据库系统中的重要优化手段,通过合理规划和应用,...
已存在的非分区表无法直接转化为分区表,需要通过特定的在线重定义操作来完成。此外,分区会增加数据库的复杂性,可能需要更多的存储空间,并且对数据库设计和维护提出了更高要求。 Oracle表分区主要有以下几种类型...
在创建Oracle表分区之前,需要先创建一个分区表实例。创建分区表实例的SQL语句如下: ``` create table DE_TEST( name_tag varchar2(10), day_tag DATE) PARTITION BY RANGE (day_tag) ( PARTITION DE_TEST_...
- 已经存在的表不能直接转化为分区表,但Oracle提供了在线重定义功能。 #### 四、表分区的类型及操作方法 1. **范围分区**:最常用的分区类型之一,根据分区键的范围将数据映射到各个分区。通常使用日期作为分区键...
Oracle数据库中的表分区是一种优化大型数据表性能的技术,它将一个大表划分为多个更小、更易管理的部分,每个部分称为一个分区。通过分区,可以提高查询速度、简化管理和维护,以及改善备份和恢复的效率。以下是...
在下载的“oracle表分区”压缩包中,可能包含了演示如何在Oracle环境中创建、操作和管理分区表的SQL脚本和文档。通过学习和实践这些示例,你可以深入理解并掌握Oracle表分区技术,从而更好地应对大数据量的挑战。
- 分区表和索引:大型表和索引可以被进一步划分为更小、更容易管理的部分。比如,Table T1 和 Index I1 可以被分割成多个分区。 分区带来的好处包括: - 表可用性:分区可以让每个分区独立管理,备份和恢复操作...
Oracle数据库中的表分区是数据库设计中的一个重要概念,它允许我们将大型数据表划分为较小、更易管理和查询的部分。本文将深入探讨Oracle表分区的详细知识,包括其原理、类型、优势以及如何在实际操作中应用。 一、...
总之,Oracle表分区是一项强大的数据库管理技术,它在处理大规模数据时提供了许多优势,但也需要数据库管理员掌握相关的知识和技能来有效管理分区表。随着数据量的不断增长,合理利用分区策略可以帮助企业节省维护...
- **维护和管理**:分区表的维护和备份恢复可能更复杂,需要考虑如何处理跨分区的操作,以及如何有效地执行分区级别的DML操作。 - **性能监控**:分区后,数据库管理员需要持续监控分区性能,适时调整分区策略,如...
本篇将详细介绍Oracle分区的原理、优缺点以及各种分区方法,并提供相关操作示例。 一、Oracle分区简介 Oracle分区的核心理念是“分而治之”,它将大表和索引分成多个小的逻辑单元,称为分区。这种技术有助于减少...
Oracle表分区技术是一种高效管理大型数据库表的策略,它通过将大表划分为较小的、独立的分区,提高数据管理的便捷性和性能。这一技术自Oracle8开始引入,旨在应对数据量急剧增长带来的挑战。 首先,分区技术的核心...
- 已存在的非分区表转换成分区表较为复杂,Oracle提供在线重定义功能解决这一问题。 - 需要更多的存储空间,因为每个分区都是独立的表空间。 - 设计和管理分区需要专业知识,增加了数据库设计的复杂性。 4. **表...
- 已经存在的表不能直接转换为分区表,但Oracle提供在线重定义表的功能,可以在一定程度上解决这一问题。 #### 四、表分区的几种类型及操作方法 - **范围分区**:根据特定的范围将数据分配到各个分区。最常见的...