在大数据量的系统中,分区表是很常见的,分区有多种类型,可以根据业务来选择自己需要的分区,不过为了数据的兼容性,需要考虑对于分
在大数据量的系统中,分区表是很常见的,分区有多种类型,可以根据业务来选择自己需要的分区,不过为了数据的兼容性,需要考虑对于分区表设定一个默认的表分区,如果数据在插入表分区的时候,,没有符合条件的分区,就会插入默认的表分区中。
这个可以根据自己的需要来设定,如果确实对数据有严格的要求,甚至可以要求不加入默认的分区。
以下的脚本会去扫描分区的信息,如果检测到没有默认的分区,就会生成对应的脚本。
可以根据自己的情况来决定是否需要加入分区。
sqlplus -s $1/$2@$sh_db_sid set head off
set pages 100
set linesize 200
/* bad performance
select name,count(*)from user_part_key_columns where object_type='table' and name in
(
select table_name from user_tables where partitioned='yes'
minus
(select distinct table_name
from user_tab_partitions where partition_name like '%max%'
)
)
group by name;
*/
select 'alter table '||table_name||' add partition pmaxvalue values less than ('||
decode(col_count, 1, 'maxvalue',
2,'maxvalue,maxvalue',
3,'maxvalue,maxvalue,maxvalue',
4,'maxvalue,maxvalue,maxvalue,maxvalue','partition out of range')||');'
from
(
(
select t1.table_name,count(t2.name) col_count from user_tables t1,user_part_key_columns t2
where t1.partitioned='yes'
and t1.table_name=t2.name
and t2.object_type='table'
group by t1.table_name
)
minus
(
select t2.name table_name,count(t2.name)col_count
from user_tab_partitions t1,user_part_key_columns t2
where t1.partition_name like '%max%'
and t1.table_name=t2.name
and t2.object_type='table'
group by t2.name
)
)
/
eof
exit
简单运行一下,可以看到有一些分区表是灭有默认的分区的。可以根据自己的情况来定夺。
[ora11g@rac1 dbm_lite]$ ksh getmaxpar.sh system oracle
alter table logmnrc_gsba add partition pmaxvalue values less than (maxvalue);
alter table logmnrc_gsii add partition pmaxvalue values less than (maxvalue);
alter table logmnrc_gtcs add partition pmaxvalue values less than (maxvalue);
alter table logmnrc_gtlo add partition pmaxvalue values less than (maxvalue);
alter table logmnrp_ctas_part_map add partition pmaxvalue values less than (maxvalue);
alter table logmnr_attrcol$ add partition pmaxvalue values less than (maxvalue);
alter table logmnr_attribute$ add partition pmaxvalue values less than (maxvalue);
alter table logmnr_ccol$ add partition pmaxvalue values less than (maxvalue);
alter table logmnr_cdef$ add partition pmaxvalue values less than (maxvalue);
alter table logmnr_col$ add partition pmaxvalue values less than (maxvalue);
alter table logmnr_coltype$ add partition pmaxvalue values less than (maxvalue);
alter table logmnr_dictionary$ add partition pmaxvalue values less than (maxvalue);
alter table logmnr_dictstate$ add partition pmaxvalue values less than (maxvalue);
alter table logmnr_enc$ add partition pmaxvalue values less than (maxvalue);
alter table logmnr_icol$ add partition pmaxvalue values less than (maxvalue);
浅谈oracle分区表之范围分区
oracle分区表迁移
oracle分区表使用实例
oracle分区表 (partition table) 的创建及管理
本文永久更新链接地址: