专栏首页杨建荣的学习笔记通过shell检查分区表中是否含有默认分区(r2笔记87天)

通过shell检查分区表中是否含有默认分区(r2笔记87天)

在大数据量的系统中,分区表是很常见的,分区有多种类型,可以根据业务来选择自己需要的分区,不过为了数据的兼容性,需要考虑对于分区表设定一个默认的表分区,如果数据在插入表分区的时候,没有符合条件的分区,就会插入默认的表分区中。 这个可以根据自己的需要来设定,如果确实对数据有严格的要求,甚至可以要求不加入默认的分区。 以下的脚本会去"扫描"分区的信息,如果检测到没有默认的分区,就会生成对应的脚本。 可以根据自己的情况来决定是否需要加入分区。

sqlplus -s $1/$2@$SH_DB_SID <<EOF
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); 

本文分享自微信公众号 - 杨建荣的学习笔记(jianrong-notes),作者:r2笔记87天

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2014-09-06

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 海量数据迁移之分区并行抽取(r2笔记53天)

    在之前的章节中分享过一些数据迁移中并行抽取的细节,比如一个表T 很大,有500G的数据,如果开启并行抽取,默认数据库中并行的最大值为64,那么生成的dump文件...

    jeanron100
  • 通过shell分析表依赖的层级关系(r3笔记第97天)

    在平时的工作环境中,总会有一些表会存在依赖关系,比如我们有三张表customer,用户表subscriber,账户表account 其中客户可以有多个用户或者账...

    jeanron100
  • MySQL中需要重视的隐式转换

    在系统集成,对接的过程中,很多时候我们都会忽略数据类型的兼容性,导致在系统运转起来的时候,原本正常的流程会容易堵塞,其中一个潜在的原因就是因为数据隐式转换带来的...

    jeanron100
  • html头部meta属性大全

    IT故事会
  • AS3中mouseEnabled和mou

    py3study
  • HTML head 头标签 总结

    HTML head 头部分的标签、元素有很多,涉及到浏览器对网页的渲染,SEO 等等,而各个浏览器内核以及各个国内浏览器厂商都有些自己的标签元素,这就造成了很多...

    前朝楚水
  • MyBatis 多参数(对象)查询(foreach)解决方法

    zcqshine
  • sql模糊匹配中%、_的处理

    guokun
  • 赵丽颖公布婚讯致微博瘫痪, 新浪程序员转发:能否提前打个招呼!

    我们都知道,在10月16号这一天,大家常玩微博的小伙伴都发现微博又陷入到了突然的瘫痪之中,这可是让大家急坏了。好多网友都说,明明就是想吃一下赵丽颖还有冯绍峰的瓜...

    一墨编程学习
  • 《论中国》的大趋势,新零售的桃花源

    孟永辉

扫码关注云+社区

领取腾讯云代金券