Oracle-在线重定义操作文档
Oracle-在线重定义操作文档
2015年10月8日
15:51
在线重定义的大致操作流程如下:
(1)创建基础表A,如果存在,就不需要操作。
(2)创建临时的分区表B。
(3)开始重定义,将基表A的数据导入临时分区表B。
(4)结束重定义,此时在DB的 Name Directory里,已经将2个表进行了交换。即此时基表A成了分区表,我们创建的临时分区表B 成了普通表。 此时我们可以删除我们创建的临时表B。它已经是普通表。
下面看一个示例:
1. 创建基本表和索引
|
SQL> create table unpar_table (id number(10) primary key,create_date date); Table created. SQL> insert into unpar_table select rownum, created from dba_objects; 72491 rows created. SQL> create index create_date_ind on unpar_table(create_date); Index created. SQL> commit; Commit complete. |
2. 收集表的统计信息
|
SQL> exec dbms_stats.gather_table_stats(ownname=>'dev',tabname=>'unpar_table', cascade => true); PL/SQL procedure successfully completed. |
3. 创建临时分区表
|
SQL> create table par_table (id number primary key, time date) partition by range (time) (partition p1 values less than (to_date('2004-7-1', 'yyyy-mm-dd')),partition p2 values less than (to_date('2005-1-1', 'yyyy-mm-dd')),partition p3 values less than (to_date('2005-7-1', 'yyyy-mm-dd')),partition p4 values less than (maxvalue)); Table created. |
4. 进行重定义操作
4.1 检查重定义的合理性
|
SQL> exec dbms_redefinition.can_redef_table(uname=>'dev',tname=>'unpar_table'); PL/SQL procedure successfully completed. |
4.2 如果4.1 没有问题,开始重定义,这个过程可能要等一会。
这里要注意:如果分区表和原表列名相同,可以用如下方式进行:
|
SQL> BEGIN DBMS_REDEFINITION.start_redef_table( uname => 'dev', orig_table => 'unpar_table', int_table => 'par_table'); end; / BEGIN * ERROR at line 1: ORA-42016: shape of interim table does not match specified column mapping ORA-06512: at "SYS.DBMS_REDEFINITION", line 52 ORA-06512: at "SYS.DBMS_REDEFINITION", line 1646 ORA-06512: at line 2 如果分区表的列名和原表不一致,那么在开始重定义的时候,需要重新指定映射关系: SQL> EXEC DBMS_REDEFINITION.START_REDEF_TABLE('dev','unpar_table','par_table','ID ID, create_date TIME',DBMS_REDEFINITION.CONS_USE_PK); PL/SQL procedure successfully completed. 这一步操作结束后,数据就已经同步到这个临时的分区表里来了。 |
4.3 同步新表,这是可选的操作
|
SQL> begin dbms_redefinition.sync_interim_table( uname => 'DEV', orig_table => 'unpar_table', int_table => 'par_table'); end; / PL/SQL procedure successfully completed. |
4.4 创建索引,在线重定义只重定义数据,索引还需要单独建立。
|
SQL> create index create_date_ind2 on par_table(time); Index created. |
4.5 收集新表的统计信息
|
SQL> exec dbms_stats.gather_table_stats(ownname=>'dev',tabname=>'par_table', cascade => true); PL/SQL procedure successfully completed. |
4.6 结束重定义
|
SQL> begin dbms_redefinition.finish_redef_table( uname => 'dev', orig_table => 'unpar_table', int_table => 'par_table'); end; / PL/SQL procedure successfully completed. 结束重定义的意义: 基表unpar_table 和临时分区表par_table 进行了交换。 此时临时分区表par_table成了普通表,我们的基表unpar_table成了分区表。 我们在重定义的时候,基表unpar_table是可以进行DML操作的。 只有在2个表进行切换的时候会有短暂的锁表。 |
5. 删除临时表
|
SQL> DROP TABLE par_table; 表已删除。 |
6. 索引重命名
|
SQL> ALTER INDEX create_date_ind2 RENAME TO create_date_ind; 索引已更改。 |
7. 验证
|
SQL> select partitioned from user_tables where table_name = 'UNPAR_TABLE'; PAR --- YES SQL> select partition_name from user_tab_partitions where table_name = 'UNPAR_TABLE'; PARTITION_NAME ------------------------------ P1 P2 P3 P4 SQL> select count(*) from unpar_table; COUNT(*) ---------- 72500 SQL> select count(*) from unpar_table partition (p4); COUNT(*) ---------- 72500 SQL> select count(*) from par_table; COUNT(*) ---------- 72500 SQL> select count(*) from unpar_table partition (p1); COUNT(*) ---------- 0 SQL> select count(*) from unpar_table partition (p2); COUNT(*) ---------- 0 |
已使用 Microsoft OneNote 2010 创建
一个用于存放所有笔记和信息的位置
Oracle-在线重定义操作文档的更多相关文章
- Oracle在线重定义(online redefinition)--将普通表改为分区表
使用Oracle的在线重定义技术,可以将Oracle的普通表改为分区表.操作如下: STEP1:测试表是否可以在线重定义,这里以unixdev数据库的LIJIAMAN.BSTEST为例 EXEC DB ...
- Oracle在线重定义DBMS_REDEFINITION 普通表—>分区表
实验环境:RHEL 6.4 + Oracle 11.2.0.3实验:在线重定义 普通表 为 分区表,包括主键对应的索引都改造为分区索引. 1,构造普通表t_objects conn test1/tes ...
- oracle在线重定义表
在一个高可用系统中,如果需要改变一个表的定义是一件比较棘手的问题,尤其是对于7×24系统.Oracle提供的基本语法基本可以满足一般性修改,但是对于把普通堆表改为分区表,把索引组织表修改为堆表等操作就 ...
- Oracle 在线重定义表分区
==================原始表================原始表=====================原始表 create table BUILDING_temp(building ...
- 通过DBMS_REDEFINITION包对表在线重定义
基础介绍 Oracle Online Redefinition可以保证在数据表进行DDL类型操作,如插入.删除数据列,分区处理的时候,还能够支持DML操作,特别是insert/update/delet ...
- oracle 11g 将非分区表转换为分区表在线重定义
--操作的用户需要有以下的权限 GRANT CONNECT, RESOURCE TO CMIGDW; GRANT EXECUTE ON DBMS_REDEFINITION TO CMIGDW; GRA ...
- Oracle 12C 新特性之在线重命名、迁移活跃的数据文件
Oracle 数据库 12c 版本中对数据文件的迁移或重命名不再需要太多繁琐的步骤,可以使用 ALTER DATABASE MOVE DATAFILE 这样的 SQL 语句对数据文件进行在线重命名和移 ...
- (Oracle)已有数据表建立表分区—在线重定义
今天在做数据抽取的时候,发现有一张业务表数据量达到了5000W,所以就想将此表改为分区表.分区表的有点如下: 1.改善查询性能:对分区对象的查询可以仅搜索自己关心的分区,提高检索速度.2.增强可用性: ...
- oracle普通表转分区表(在线重定义方式)
1.1.TAB_TAOBAO_BILL 1.1.1检查下这张表是否可以在线重定义,无报错表示可以,报错会给出错误信息: exec dbms_redefinition.can_redef_table(' ...
随机推荐
- LeetCode 面试:Add Binary
1 题目 Given two binary strings, return their sum (also a binary string). For example,a = "11&quo ...
- 重构第四天 : 用多态替换条件语句(if else & switch)
面相对象的一个核心基础就是多态,当你要根据对象类型的不同要做不同的操作的时候,一个好的办法就是采用多态,把算法封装到子类当中去. 重构前代码: public abstract class Custom ...
- 【转】Java ConcurrentModificationException 异常分析与解决方案--还不错
原文网址:http://www.2cto.com/kf/201403/286536.html 一.单线程 1. 异常情况举例 只要抛出出现异常,可以肯定的是代码一定有错误的地方.先来看看都有哪些情况会 ...
- 织梦CMS(dedecms)栏目属性及系统封面模板、列表模板、文章模板区别和路径设置解答
问题一:(织梦"栏目管理"的"常规选项"中3个栏目属性分析?) 织梦CMS的栏目属性分成三种, -->最终列表栏目 -->频道封面 -->外部 ...
- Android学习笔记(六)Fragment的生命周期
在上一篇博文中对Fragment做了简单的介绍,现在再来探讨一下Fragment的生命周期. 一.Fragment的几种状态: 与Activity类似,Fragment也有一下几种状态: · 活动状态 ...
- 如何理解这段代码:void (*signal (int sinno,void(*func)(int)))(int)
void (*signal (int sinno,void(*func)(int)))(int) 先来看void(*func)(int) 这里的意思是声明一个函数指针func,它的参数类型为int ...
- galera mysql 多主复制启动顺序及命令
Mysql 被复制机 sql启动
- Circle - SGU 130(递推)
题目大意:一个圆上有2K个点,用K个线把他们连接起来,求出这些线最少可以把这个圆分成P部分,有N种分割方法.输出N和P. 分析:分割线一定是相互不相交的线,所以可以把这写分成两部分,f[i] += f ...
- redis中各种数据类型对应的jedis操作命令
redis中各种数据类型对应的jedis操作命令 一.常用数据类型简介: redis常用五种数据类型:string,hash,list,set,zset(sorted set). 1.String类型 ...
- MapObject shape数据操作
利用MO 的GeoDataset .DataConnection Recordset 进行数据操作 在MO中.使用GeoDataset对象和DataConnection 对象来连接和读取地理数据. ...