Oracle 11g 间隔分区(INTERVAL)批量规范命名

友情提示:请在业务空闲是操作。为什么呢?


--Oracle 11g 间隔分区(INTERVAL)重命名,批量生成rename分区脚本
set linesize 
180
set serverout on
declare
  v_table_owner          varchar2(100) := 
‘OP%‘;
  v_table_name_day_p     varchar2(100);
  v_table_name_month_p   
varchar2(100);
  v_print                number:=1; --1:只打印执行脚本,2,DB直接执行
  v_new_partition_name   varchar2(100);
  v_sql                  
varchar2(2000);
  vSqlerrm               varchar2(256);
begin
  for i 
in (select t1.table_owner,
       t2.table_name,
       t1.partition_name,
       t2.interval,
       t1.high_value
  from 
dba_tab_partitions t1,dba_part_tables t2 
 where t2.owner = 
t1.table_owner
   and t2.table_name = t1.table_name
   and t1.interval = 
‘YES‘
   and t2.partitioning_type=‘RANGE‘
   and t1.partition_name like 
‘SYS\_%‘ escape ‘\‘
   and table_owner like v_table_owner order by 
t1.table_owner,t1.partition_name) loop
    if 
i.interval=‘NUMTODSINTERVAL(1,‘‘DAY‘‘)‘ then
    v_table_name_day_p := 
substr(i.table_name, 1, 19);  --日分区取前19位字符;
    execute immediate ‘select 
to_char(‘ || i.high_value ||
                      ‘ - 
NUMTODSINTERVAL(1,‘‘DAY‘‘), ‘‘"‘ ||
                      v_table_name_day_p 
|| ‘"YYYY"M"MM"D"DD‘‘) from dual‘     
      into 
v_new_partition_name;
    elsif i.interval=‘NUMTOYMINTERVAL(1,‘‘MONTH‘‘)‘  
then
    v_table_name_month_p := substr(i.table_name, 1, 23); 
--月分区取前23位字符;
    execute immediate ‘select to_char(‘ || i.high_value 
||
                      ‘ - NUMTOYMINTERVAL(1,‘‘MONTH‘‘), ‘‘"‘ 
||
                      v_table_name_month_p || ‘"YYYY"M"MM‘‘) from 
dual‘
      into v_new_partition_name;
    end if;
    if v_print=1 
then
    dbms_output.put_line(‘alter table ‘ || i.table_owner || ‘.‘ 
||i.table_name || ‘ rename partition ‘ ||i.partition_name || ‘ to ‘ || 
v_new_partition_name || ‘;‘);
    elsif v_print=2 then
        v_sql := 
‘alter table ‘ || i.table_owner || ‘.‘ ||i.table_name || ‘ rename partition ‘ 
||i.partition_name || ‘ to ‘ || v_new_partition_name;
        execute 
immediate v_sql;
    end if;
  end loop;
exception
  when others 
then
    vSqlerrm := sqlerrm;
    dbms_output.put_line(vSqlerrm||‘|‘||v_sql);
end;
时间: 2024-12-22 17:20:07

Oracle 11g 间隔分区(INTERVAL)批量规范命名的相关文章

oracle 11G 间隔分区

在项目数据库设计过程中由于单表的数据量非常庞大,需要对表进行分区处理.由于表中的数据是历史交易,故按月分区,提升查询和管理. 由于之前对于表分区了解不多,为了实现上述功能查了很多资料,一开始的方向是通过Crontab调用Shell脚本来按月自动创建分区,或者使用 Oracle的Job调用存储过程来自动创建分区.在研究上述两套方案的过程中,无意发现Oracle11g有间隔分区功能,对于使用Range分区的可 以按年,月,日来自动生成分区.语法如下: [sql] view plaincopy CRE

Oracle 11g 间隔分区,导出报错 EXP-00006

一.描述前天系统对个别表进行分区,采用间隔分区,第二天凌晨exp备份间隔分区表报错,报错关键字EXP-00006 二.现象 When exporting a composite. interval, or system partitioned table using conventional export utility, it fails with EXP-6 and EXP-0 errors: EXP-00006: internal inconsistency errorEXP-00000:

oracle 11g 新增分区

oracle 11g新增了间隔分区.虚拟列分区和引用分区.详细的介绍请查看官方文件: Creating Partitions 1. 间隔分区 间隔分区是范围分区的一种扩展.在引入间隔分区之前,DBA 需要显式定义每个分区的值范围,随着分区值的增长可用分区会逐渐减少直到没有可使用的分区为止.而间隔分区就是为了解决插入表中的数据超过了所有范围分区时而不能自动创建分区的问题.必须至少创建一个范围分区,范围分区的键值确定范围分区的上限值,超过该上限值数据库服务器自动创建特定间隔的分区.主要用在可预知的添

Oracle 11g新特性 Interval Partition

分区(Partition)一直是Oracle数据库引以为傲的一项技术,正是分区的存在让Oracle高效的处理海量数据成为可能,在Oracle 11g中,分区技术在易用性和可扩展性上再次得到了增强.在10g的Oracle版本中,要对分区表做调整,尤其是对RANGE分区添加新的分区都需要DBA手动定期添加,或都使用存储过程进行管理.在11G的版本中的Interval Partition不再需要DBA去干预新分区的添加,Oracle会自动去执行这样的操作,减少了DBA的工作量.Interval Par

oracle 11g 分区

1.间隔分区 interval分区是范围分区的增强,可以实现范围分区的自动化,可以自动创建新的分区和本地索引. 测试例子: 先创建一个分区表, 写入不在分区范围内的数据 查看分区已经自动建立了,但是分区名无法指定,对于根据分区名进行备份清理来说,这个貌似还是不智能. DROP TABLE EDU.TEST23 PURGE / CREATE TABLE EDU.TEST23 (ID NUMBER(12), NAME VARCHAR2(20), CREATE_DATE DATE ) PARTITIO

Oracle 11g 新特性:自动创建分区(Interval Partition)

分区(Partition)一直是Oracle数据库引以为傲的一项技术,正是分区的存在让Oracle高效的处理海量数据成为可能,在Oracle 11g中,分区技术在易用性和可扩展性上再次得到了增强.在10g的Oracle版本中,要对分区表做调整,尤其是对RANGE分区添加新的分区都需要DBA手动定期添加,或都使用存储过程进行管理.在11G的版本中的Interval Partition不再需要DBA去干预新分区的添加,Oracle会自动去执行这样的操作,减少了DBA的工作量.Interval Par

Oracle 11g 通过间隔分区实现按月创建表分区

在项目数据库设计过程中由于单表的数据量非常庞大,需要对表进行分区处理.由于表中的数据是历史交易,故按月分区,提升查询和管理. 由于之前对于表分区了解不多,为了实现上述功能查了很多资料,一开始的方向是通过Crontab调用Shell脚本来按月自动创建分区,或者使用Oracle的Job调用存储过程来自动创建分区.在研究上述两套方案的过程中,无意发现Oracle11g有间隔分区功能,对于使用Range分区的可以按年,月,日来自动生成分区.语法如下: CREAT TABLE TABLE1 ( TABLE

使用Oracle 11g分区自动扩展的功能的一个小问题

Oracle 11g下使用分区自动扩展的功能,非常方便,不过同时也带来一个问题,就是导出.导入之后,建表语句改了,下面来做个实验: SQL> select * from v$version; BANNER ------------------------------------------------------------------------------ Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Pr

Oracle 11g下自动创建分区

11g之前,维护分区需要手工.11g之后使用interval来实现自动扩展分区,简化了维护. 根据年  INTERVAL(NUMTOYMINTERVAL(1,'YEAR')) 根据月  INTERVAL(NUMTOYMINTERVAL(1,'MONTH')) 根据天  INTERVAL(NUMTODSINTERVAL(1,'DAY')) 下面用按月自动扩展来做个试验: SQL> create table t_range (id number not null PRIMARY KEY, test_