您好,欢迎访问一九零五行业门户网

通过shell检查Oracle分区表中是否含有默认分区

在大数据量的系统中,分区表是很常见的,分区有多种类型,可以根据业务来选择自己需要的分区,不过为了数据的兼容性,需要考虑对于分
在大数据量的系统中,分区表是很常见的,分区有多种类型,可以根据业务来选择自己需要的分区,不过为了数据的兼容性,需要考虑对于分区表设定一个默认的表分区,如果数据在插入表分区的时候,,没有符合条件的分区,就会插入默认的表分区中。
这个可以根据自己的需要来设定,如果确实对数据有严格的要求,甚至可以要求不加入默认的分区。
以下的脚本会去扫描分区的信息,如果检测到没有默认的分区,就会生成对应的脚本。
可以根据自己的情况来决定是否需要加入分区。
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) 的创建及管理
本文永久更新链接地址:
其它类似信息

推荐信息