oracle如何分区功能 oracle的分区表

Oracle创建分区表操作1、创建语句
create table p(id number)
partition by range(id)
(partition p1 values less than(100) tablespace t1,
partition p2 values less than(200) tablespace t2,
partition p3 values less than(300) tablespace t3);
2、添加分区
alter table p add partition p4 values less than (400) tablespace t4;
3、清除分区数据
alter table p trunc partition p1;
4、删除分区
alter table p drop partition p1;
oracle具体怎么分区你说的是oracle分区表吧 , 一般数据量大的表格采用到此功能 , 一个表上千万数据以上 。以下例子,分区创建需要有条件,如时间,语法可详见metalink
CREATE TABLE T_NEW (ID NUMBER PRIMARY KEY, TIME DATE)
PARTITION BY RANGE (TIME)
(PARTITION P1 VALUES LESS THAN (TO_DATE('2005-7-1', 'YYYY-MM-DD')),
PARTITION P2 VALUES LESS THAN (MAXVALUE));
oracle分区表有什么作用?Oracle的表分区功能通过改善可管理性、性能和可用性,从而为各式应用程序带来了极大的好处,分区功能能够将表、索引或索引组织表进一步细分为段,这些数据库对象的段叫做分区 。
范围分区(RANGE)
范围分区将数据基于范围映射到每一个分区 , 这个范围是你在创建分区时指定的分区键决定的 。这种分区方式是最为常用的,并且分区键经常采用日期 。当使用范围分区时,请考虑以下几个规则:
1)每一个分区都必须有一个VALUES LESS THEN子句,它指定了一个不包括在该分区中的上限值 。分区键的任何值等于或者大于这个上限值的记录都会被加入到下一个高一些的分区中 。
2)所有分区,除了第一个,都会有一个隐式的下限值 , 这个值就是此分区的前一个分区的上限值 。
3)在最高的分区中,MAXVALUE被定义 。MAXVALUE代表了一个不确定的值 。这个值高于其它分区中的任何分区键的值,也可以理解为高于任何分区中指定的VALUE LESS THEN的值,同时包括空值 。
)本地分区索引
本地分区索引是使用了LOCAL属性创建的分区索引,其特征是索引分区的所有键均指向其基表某个 唯一分区中存储的相应行 。Oracle创建本地分区索引的目的就是要确保索引也是分区管理的 , 而且索引的分区与表的分区是均衡的,也就是本地分区索引具有与其基表相同的分区、子分区,即分区键等同于表的分区键、分区数等同于表的分区数 。
任何基表分区的增加、删除、合并、分割操作,或者散列分区增加或合并操作,Oracle会通过其自身的机制自动维护本地分区索引相应的分区,此即本地分区索引与基表的均衡性原则 。
如果分区列能够形成索引列的一个子集 , 则本地分区索引可以是唯一索引 。该限制能确保具有相同索引键的行始终映射到同一个分区,在该分区中,违反唯一性的行为能被检测到 。
oracle11g自动分区在Oracle10g中 , 没有定义间隔分区,只能通过范围分区实现间隔分区功能,如果要实现自动创建分区,只能通过创建JOB或者scheduler来实现;而在11g中 , Oracle直接提供了间隔分区功能,大大简化了间隔分区的实现 。
----注:oracle11g虽然可以自动分区,但是分区的名字不能自定义 , 对于需要定时删除分区时没法处理 , 不如通过时间范围来手工分区 。详见
create table HIP_LOG_NODE_Part
(
IDVARCHAR2(32)not null,
RECORD_TIMEDATE
)tablespace TB_HIP_LOG_NODE
PARTITION BY RANGE (RECORD_TIME) interval (numtoyminterval(1, 'month'))
STORE IN (TB_HIP_LOG_NODE)
(
partition hip_log_node_partition values less than (to_date('2019-08-01 00:00','yyyy-MM-dd HH24:mi')) tablespace TB_HIP_LOG_NODE
);
1、Oracle11g有间隔分区功能 , 对于使用Range分区的可以按年,月,日来自动生成分区 。
2、2019-08-01前的数据(包含8月份的数据)会放入hip_log_node_partition 分区 , 8月1日后的数据每月只要有数据,就会自动创建一个分区 。也就是从9月开始 , 开始新建分区 。
3、interval函数--将数值按标准换算为日期
numtodsinterval、numtodsinterval函数,将数字转成年月,时分秒
详见:
4、查看表分区 select table_name,partition_name from user_tab_partitions where table_name='INTERVAL_SALES';
5、插入数据再次查看分区,详见:
6、修改分区、合并分区、拆分分区,详见 :
7、创建索引(分区索引、全局索引) :
非分区字段创建主键,则创建主键local索引时必须加上分区字段
ALTER TABLE TEST ADD CONSTRAINT PK_TEST PRIMARY KEY (主键字段,分区字段) USING INDEX LOCAL;
8、oracle 10g创建表分区
9、删除
1.不保留,直接删除:
alter table table_name drop/truncate partition partition_name;
具体用drop还是truncate , 得你自己衡量,drop的话原来的分区和数据直接就没有了,truncate的话,只是数据没有了,分区还在 。
oracle分区表的分区有几种类型【oracle如何分区功能 oracle的分区表】oracle分区表的分区有四种类型:范围分区、散列分区、列表分区和复合分区 。
特点如下:
1、范围分区
就是根据数据库表中某一字段的值的范围来划分分区 。
数据中有空值 , Oracle机制会自动将其规划到maxvalue的分区中 。
2、散列分区
根据字段的hash值进行均匀分布,尽可能地实现各分区所散列的数据相等 。
散列分区即为哈希分区,Oracle采用哈希码技术分区,具体分区如何由Oracle说的算,也可能我下一次搜索就不是这个数据了 。
3、列表分区
列表分区明确指定了根据某字段的某个具体值进行分区,而不是像范围分区那样根据字段的值范围来划分的 。
4、复合分区
根据范围分区后,每个分区内的数据再散列地分布在几个表空间中,这样我们就要使用复合分区 。复合分区是先使用范围分区,然后在每个分区同再使用散列分区的一种分区方法 。
比如将part_date的记录按时间分区,然后每个分区中的数据分三个子分区,将数据散列地存储在三个指定的表空间中 。
扩展资料:
分区的恢复方法:
如果数据库运行在archive 模式下,那么一旦数据库损坏则可以通过冷备份(热备份)和归档备份将数据库恢复到断点状态 。
数据库控制文件恢复(假设所有控制文件均被破坏):
数据库基于文件系统: 利用操作系统的tar、cp等命令即可 。
数据库基于裸设备:dd if=$ORACLE_BASE/con.bak of=/dev/rdrd/drd1 seek=12
参考资料来源:百度百科-oracle数据库
Oracle分区之四:分区维护和管理 一 分区表的相关实验 创建一个列表分区表 create table t (id number city varchar ( )) partition by list(city) ( partition p values ( SH JS ZJ ) partition p values ( BJ TJ HB ) partition p values ( GZ SZ ) partition p_others values (default) ); create or replace procedure proc as begin for i in loop execute immediate INSERT INTO T values(:x :y) USING i SH ; end loop; end; / exec proc create or replace procedure proc as begin for i in loop execute immediate INSERT INTO T values(:x :y) USING i JS ; end loop; end; / exec proc create or replace procedure proc as begin for i in loop execute immediate INSERT INTO T values(:x :y) USING i ZJ ; end loop; end; / exec proc create or replace procedure proc as begin for i in loop execute immediate INSERT INTO T values(:x :y) USING i BJ ; end loop; end; / exec proc create or replace procedure proc as begin for i in loop execute immediate INSERT INTO T values(:x :y) USING i TJ ; end loop; end; / exec proc create or replace procedure proc as begin for i in loop execute immediate INSERT INTO T values(:x :y) USING i GZ ; end loop; end; / exec proc create or replace procedure proc as begin for i in loop execute immediate INSERT INTO T values(:x :y) USING i HB ; end loop; end; / exec proc create or replace procedure proc as begin for i in loop execute immediate INSERT INTO T values(:x :y) USING i SZ ; end loop; end; / exec proc create or replace procedure proc as begin for i in loop execute immediate INSERT INTO T values(:x :y) USING i AH ; end loop; end; / exec proc SQL SET linesize SQL select TABLE_NAME TABLE_OWNER PARTITION_NAME SUBPARTITION_COUNT from dba_tab_partitions where table_name= T ; TABLE_NAME TABLE_OWNER PARTITION_NAME SUBPARTITION_COUNT T HR P T HR P T HR P T HR P_OTHERS
实验一(SPLIT 分区) alter table t split partition p values ( JS ) into (partition p _ partition p _ ); SQL select TABLE_NAME TABLE_OWNER PARTITION_NAME SUBPARTITION_COUNT from dba_tab_partitions where table_name= T ; TABLE_NAME TABLE_OWNER PARTITION_NAME SUBPARTITION_COUNT T HR P _ T HR P _ T HR P T HR P T HR P_OTHERS
实验二(merge 分区) alter table t merge partitions p _ p _ into partition p ; SQL select TABLE_NAME TABLE_OWNER PARTITION_NAME SUBPARTITION_COUNT from dba_tab_partitions where table_name= T ; TABLE_NAME TABLE_OWNER PARTITION_NAME SUBPARTITION_COUNT T HR P T HR P T HR P T HR P_OTHERS 实验三 alter table t split partition p values ( BJ TJ ) into (partition p _ partition p _ ); SQL select TABLE_NAME TABLE_OWNER PARTITION_NAME SUBPARTITION_COUNT from dba_tab_partitions where table_name= T ; TABLE_NAME TABLE_OWNER PARTITION_NAME SUBPARTITION_COUNT T HR P T HR P _ T HR P _ T HR P T HR P_OTHERS
实验四 alter table t merge partitions p _ p _ into partition p ; SQL select TABLE_NAME TABLE_OWNER PARTITION_NAME SUBPARTITION_COUNT from dba_tab_partitions where table_name= T ; TABLE_NAME TABLE_OWNER PARTITION_NAME SUBPARTITION_COUNT T HR P T HR P T HR P T HR P_OTHERS 实验五( 向分区某个分区里增加个分区列值) SQL alter table t modify partition p add values( ZQ ); Table altered 二 分区索引的相关实验 实验六(创建索引分区) create index idx_t on t (id) global partition by range(id) ( partition p values less than ( ) partition p values less than (maxvalue) ); drop index idx_ create index idx_t on t (id) global partition by hash(id) partitions ; create table tt (id number createdate date) partition by range(createdate) subpartition by hash(id) subpartitions ( partition p values less than (to_date( yyyy mm dd )) partition p values less than (to_date( yyyy mm dd )) ); create table tt (id number name varchar ( )) partition by range(name) ( partition p values less than ( h ) partition p values less than ( o ) ); create index idx_tt on tt (id) local; drop indexe idx_tt ; create index idx_tt on tt (id) global partition by range(id) ( partition p values less than ( ) partition p values less than (maxvalue) ); SQL SET LINESIZE SQL select INDEX_OWNER INDEX_NAME PARTITION_NAME FROM dba_Ind_Partitions where index_name= IDX_TT ; INDEX_OWNER INDEX_NAME PARTITION_NAME HR IDX_TT P HR IDX_TT P
alter index idx_tt split partition p at ( ) into (partition p partition p_max); SQL select INDEX_OWNER INDEX_NAME PARTITION_NAME FROM dba_Ind_Partitions where index_name= IDX_TT ; INDEX_OWNER INDEX_NAME PARTITION_NAME HR IDX_TT P HR IDX_TT P HR IDX_TT P_MAX
三 分区表交换的相关实验 Exchange partition提供了一种方式 让你在表与表或分区与分区之间迁移数据 注意不是将表转换成分区或非分区的形式 而仅只是迁移表中数据(互相迁移) 由于其号称是采用了更改数据字典的方式 因此效率最高(几乎不涉及io操作) Exchange partition适用于所有分区格式 你可以将数据从分区表迁移到非分区表 也可以从非分区表迁移至分区表 或者从hash partition到range partition诸如此类 其语法 alter table tbname exchange partition/subpartition ptname with table tbname ; 注意 在将未分区表的数据迁移到分区表中时 可能出现ora 的错误 虽然可以用without validation去解决 但是此时进入分区表的数据可能不符合分区规 则 所以without validation一定要慎用 a 涉及交换的两表之间表结构必须一致 除非附加with validation子句; b 如果是从非分区表向分区表做交换 非分区表中的数据必须符合分区表中指定分区的规则 除非附加without validation子句; c 如果从分区表向分区表做交换 被交换的分区的数据必须符合分区规则 除非附加without validation子句; d Global索引或涉及到数据改动了的global索引分区会被置为unusable 除非附加update indexes子句 注意 一旦附加了without validation子句 则表示不再验证数据有效性 因此指定该子句时务必慎重
创建一个交换分区的普通heap表 SQL create table exchange_t (id number city varchar ( )); Table created SQL select distinct city from t partition (p ); CITY TJ BJ HB 查看下P 分区有records SQL select count(*) from t partition (p ); COUNT(*) 下面是分区表和普通HEAP表交换 alter table t exchange partition p with table exchange_t including indexes without validation; 验证下数据 和上面的P 分区数据一致 SQL select count(*) from exchange_t ; COUNT(*) SQL select distinct city from exchange_t ; CITY TJ BJ HB 四 一个实际应用的例子的相关实验 创建一个分区表 只保留最近 年的财务数据 create table ware(wareyear varchar ( ) id number) partition by range (wareyear) ( partition p_ values less than( ) partition p_ values less than( ) partition p_max values less than(maxvalue) ); 创建索引 create index idx_ware_id on ware(id) global partition by range(id) ( partition p_id_ values less than( ) partition p_id_max values less than(maxvalue) ); create index idx_ware_wareyear on ware(wareyear) local; 插入测试数据 insert into ware select object_id from dba_objects; insert into ware select object_id from dba_objects; mit; 年终 归档最早的数据 并加入新财年的数据 create table ware_ (wareyear varchar ( ) id number); create index idx_ware_ on ware_ (wareyear); insert into ware_ select object_id from dba_objects; mit; alter table ware split partition p_max at ( ) into (partition p_ partition p_max); 将p_ 分区放入ware_ 表里 alter table ware exchange partition p_ with table ware_ including indexes without validation; create table ware_ (wareyear varchar ( ) id number); create index idx_ware_ on ware_ (wareyear); alter table ware exchange partition p_ with table ware_ including indexes without validation; 删除p_ 分区 alter table ware drop partition p_ ; 导出做归档 [oracle@even admin]$ exp hr/hr@test file=/home/oracle/ware_ dmp tables=ware_ press=n Export: Release Production on Fri Jan : : Copyright (c) Oracle All rights reserved
Connected to: Oracle Database g Enterprise Edition Release Production With the Partitioning Oracle Label Security OLAP and Data Mining options Export done in US ASCII character set and AL UTF NCHAR character set server uses AL UTF character set (possible charset conversion) About to export specified tables via Conventional Path exporting table WARE_ rows exported Export terminated successfully without warnings 然后删除表 drop table ware_ ;
五 表和索引的维护的常见SQL语句及注意事项 对于分区索引 不能整体进行重建 只能对单个分区进行重建(也就是物理存在的分区) 语法如下 Alter index idx_name rebuild partition index_partition_name [online nologging] Alter Index IndexName Rebuild Partition P_Name; 有子分区的本地索引 不能重建某分区 只能对每个子分区进行重建 Alter Index Index_Name Rebuild subPartition P_Sub_Name; 脚本 重建所有unUsable的索引 Select alter index || Index_Name || rebuild; From User_Indexes Where Status = UNUSABLE union Select alter index || Index_Name || rebuild Partition ||Partition_Name || ; From User_Ind_Partitions Where Status = UNUSABLE union Select alter index || Index_Name || rebuild subPartition ||subPartition_Name || ; From User_Ind_subPartitions Where Status = UNUSABLE ;
add parttion Alter Table TestTab Add Partition P Values Less Than ( ); 如果有子分区 且定义了子分区模板 所有的子分区会自动添加 新加分区后 该区没有统计信息 全是空 如果表级不是global_satus 则表级的统计信息也会空 新加分区后 如果表级统计是global_satus 还会出现out of range的问题(CBO估算的选择率很低) 解决 问题的方法是 copy_table_stats exec dbms_stats copy_table_stats(user tabname = TEST_TAB srcpartname = P_ dstpartname = P_ );
tuncate and drop partition truncate和drop可对有子分区的分区进行 ALTER TABLE TEST truncate Partition P_ ; ALTER TABLE TEST Drop Partition P_ ; 它们会导致globl index的某些分区不可用 必须这样做 ALTER TABLE TEST truncate Partition P_ update indexes; ALTER TABLE TEST truncate Partition P_ update global indexes; ALTER TABLE TEST Drop Partition P_ update indexes; ALTER TABLE TEST Drop Partition P_ update global indexes;
move partition 有子分区的分区不能move 只能move每个子分区(也就是物理分区) Alter Table TEST Move Partition P_ ; 由于rowid变了 会导致所有相关索引unusable 必须这样做 Alter Table TEST Move subPartition P_ _P update indexes; Alter Table TEST Move subPartition P_ _P update global indexes; Local Index没有更新 split partion 语法 alter table table_name split partition partition_name at (value) into (partition partition_name partition partition_name) [update [global] indexes]; 可以对有子分区的分区进行 自动split子分区 由于rowid变了 新分区和global index都变为unusable alter table t merge partitions p _ p _ into partition p ; 合并range分区 ALTER TABLE Test_Tab Merge Partitions P_ P_ Into Partition P_ [Update [global] Indexes]; 该分区有子分区 有子分区 也可以单独合并子分区merge subpartition
lishixinzhi/Article/program/Oracle/201311/19037
关于oracle如何分区功能和oracle的分区表的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站 。

    推荐阅读