oracle对表进行分区
oracle对表进行分区在建设数据仓库过程中,经常会有大量数据,短时间内表中数据量有限,查询性能还可以,但随着时间的延长,表中数据量迅速增加,查询速度就会变慢,性能下降,这时就要考虑对表进行分区。一、oracle的分区当表中的数据量不断增大,查询数据的速度就会变慢,应用程序的性能就会下降,这时就应该考虑对表进行分区。表进行分区后,逻辑上表仍然是一张完整的表,只是将表中的数据在物理上存放到多个表空间(物理文件上),这样查询数据时,不至于每次都扫描整张表。二、oracle分区的作用Oracle的表分区功能通过改善可管理性、性能和可用性,从而为各式应用程序带来了极大的好处。通常,分区可以使某些查询以及维护操作的性能大大提高。此外,分区还可以极大简化常见的管理任务,分区是构建千兆字节数据系统或超高可用性系统的关键工具。分区功能能够将表、索引或索引组织表进一步细分为段,这些数据库对象的段叫做分区。每个分区有自己的名称,还可以选择自己的存储特性。从数据库管理员的角度来看,一个分区后的对象具有多个段,这些段既可进行集体管理,也可单独管理,这就使数据库管理员在管理分区后的对象时有相当大的灵活性。三、oracle的分区包括集中:1.LIST分区2.RANGE分区3.HASH分区4.范围-散列分区5.范围-列表分区四、oracle RANGE分区 例子1.创建表,创建分区createtable TMP_LXQ_1(PROPOSALNO VARCHAR2(22),DEMANDNO VARCHAR2(50) not null,POLICYNO VARCHAR2(22),LICENSENO VARCHAR2(15),STARTDATE DATE,ENDDATE DATE)partition byrange(STARTDATE) (partition part_t01values less than(to_date('2008-01-01','yyyy-mm-dd')) ,partition part_t02values less than(to_date('2009-01-01','yyyy-mm-dd')) ,partition part_t03values less than(to_date('2010-01-01','yyyy-mm-dd')) ,partition part_t04values less than(to_date('2011-01-01','yyyy-mm-dd')) ,partition part_t05values less than(to_date('2012-01-01','yyyy-mm-dd')) ,partition part_t06values less than(to_date('2013-01-01','yyyy-mm-dd')) ,partition part_t07values less than(maxvalue));2.查询分区信息--通过user_tab_partitions 视图查看SELECT partition_name, high_valueFROM user_tab_partitionsWHERE table_name = 'TMP_LXQ_1';--通过user_part_key_columns视图查看分区表使用的列SELECT* FROM user_part_key_columns WHERE name = 'TMP_LXQ_1';3.添加分区ALTERTABLE TMP_LXQ_1ADD PARTITIONpart_t08 VALUES LESS THAN (to_date('2014-01-01','yyyy-mm-dd'));4.删除分区ALTERTABLE TMP_LXQ_1 DROP PARTITIONpart_t07;--当删除了一个分区,也同时删除了该分区中所有的数据。5.合并分区--注:不能将分区合并到界限较低的分区。--下面的SQL,分别将p201001- p201009合并为3个分区--注:普通的表分区,只能2个分区合成1个分区。3个合成1个的时候,会抱错。ALTERTABLE TMP_LXQ_1MERGE PARTITIONSpart_t01,part_t02,part_t03INTO PARTITIONpart_t03;--错误:--ORA-14126:只有<并行子句>可遵循结果分区的说明--合并分区ALTERTABLE TMP_LXQ_1MERGE PARTITIONSpart_t01,part_t02INTO PARTITIONpart_t02;6.拆分分区ALTER TABLE TMP_LXQ_1SPLIT PARTITIONpart_t02 AT(TO_DATE('2008-01-01','YYYY-MM-DD'))INTO (PARTITIONpart_t01,PARTITION part_t02);五、oracle LIST分区 例子drop tabletmp_test1;create tabletmp_test1(comcode varchar2(10)not null,comnamevarchar2(120) not null,score decimal(18,2)null)PARTITION BY LIST(comcode) (PARTITIONcomcode_beijing VALUES ('100000000'),PARTITIONcomcode_tianjin VALUES ('200000000'),PARTITIONcomcode_shanghai VALUES ('300000000'),PARTITIONcomcode_hebei VALUES ('400000000','410000000'),PARTITIONcomcode_shandong VALUES ('500000000'),PARTITIONcomcode_neimenggu VALUES ('600000000'));insert intotmp_test1select'100000000','北京',100 from dual;commit;insert intotmp_test1select'200000000','天津',100 from dual;commit;insert intotmp_test1select'300000000','上海',100 from dual;commit;insert intotmp_test1select'400000000','河北',100 from dual;commit;insert intotmp_test1select'500000000','山东',100 from dual;commit;insert intotmp_test1select'600000000','内蒙',100 from dual;commit;1.添加分区ALTER TABLEtmp_test1ADD PARTITIONcomcode_henan VALUES ('700000000');2.删除分区ALTER TABLEtmp_test1DROP PARTITIONcomcode_henan;3.拆上一个:oracle的存储过程优缺点
下一个:oracle的触发器增删改实例
- 更多Oracle疑问解答:
- 运行exp备份oracle数据库提示oracle-12154错误
- 有没有,生产Oracle Rman 备份脚本的工具啊!
- 初学orcle,希望有大大帮忙解说一下详细步骤,从登录oracle到创建表的过程
- oracle语句问题:一张user表,三个字段,id,name,time,插入记录比如:张三2007,李四2008,张三2011
- 如何写一个ORACLE触发器同步两个表中的数据?
- oracle 如何查看一个服务器上有多少个数据库.
- oracle 创建包的时候错误 求解
- oracle 重复列的问题
- oracle 中如何查处2星期前的数据
- 请教oracle数据库安装中的问题
- 请问谁能提供给我标准的oracle ERP的数据库表结构并详细说明各表主要的作用?
- 安装oracle遇到的问题 invalid entry CRC (expected 0x3e12e795 but got 0x9db0e9fd)
- 我的是ORACLE 10G,在RMAN中如何按指定的时间恢复数据文件啊?
- oracle为什么没有自动增长列
- oracle快捷键都有哪些啊?