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

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

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=' rel="nofollow"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);

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/23718752/viewspace-1263626/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/23718752/viewspace-1263626/

GPT(GUID Partition Table)是一种磁盘分区表的格式,用于替代传统的MBR(Master Boot Record)分区表。GPT分区表支持更大的磁盘容量和更多的分区,并提供了更好的数据保护机制。下面是在Linux系统使用GPT分区和挂载的步骤: 1. 确认磁盘设备:使用以下命令之一确认要分区磁盘设备: ```shell sudo fdisk -l sudo lsblk ``` 2. 创建GPT分区:使用`gdisk`命令创建GPT分区。例如,创建一个新的GPT分区表并添加一个主分区: ```shell sudo gdisk /dev/sdX n # 创建新分区 <Enter> # 默认分区编号 <Enter> # 默认起始扇区 <Enter> # 默认结束扇区 <Enter> # 默认分区类型 w # 保存并退出 ``` 请将`/dev/sdX`替换为实际的磁盘设备名称,例如`/dev/sda`。 3. 格式化分区:使用`mkfs`命令格式化新创建的分区。例如,格式化为ext4文件系统: ```shell sudo mkfs.ext4 /dev/sdX1 ``` 请将`/dev/sdX1`替换为实际的分区设备名称。 4. 创建挂载点:选择一个目录作为挂载点,用于将分区挂载到文件系统。例如,创建一个名为`/mnt/mydisk`的挂载点: ```shell sudo mkdir /mnt/mydisk ``` 5. 挂载分区:使用`mount`命令将分区挂载到挂载点。例如,将分区`/dev/sdX1`挂载到`/mnt/mydisk`: ```shell sudo mount /dev/sdX1 /mnt/mydisk ``` 请将`/dev/sdX1`替换为实际的分区设备名称。 6. 配置自动挂载:如果希望在系统启动时自动挂载分区,需要将分区信息添加到`/etc/fstab`文件。打开`/etc/fstab`文件并添加以下行: ```shell /dev/sdX1 /mnt/mydisk ext4 defaults 0 2 ``` 请将`/dev/sdX1`和`/mnt/mydisk`替换为实际的分区设备名称和挂载点。 现在,您已经了解了如何在Linux系统使用GPT分区和挂载。如果您有任何进一步的问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值