Oracle 在线重定义

Oracle 在线重定义(Online Redefinition) 是一种功能,通过DBMS_REDEFINITION 包提供,允许DBA在不需要停止或显著影响数据库正常操作的情况下,对数据库表进行结构化修改。

可以实现的功能

  • 将表移动到其它表空间

  • 增加、修改或者删除表的字段

  • 将非分区表转换为分区表

  • 修改表的分区结构

  • 高水位线回收

  • 将普通表转换为索引组织表

测试数据

五千万条数据,数据文件test_tbs01.dbf,表空间test_tbs

将表移动到其它表空间

#创建新表空间
CREATE TABLESPACE new_tbs DATAFILE '/datafile/new_tbs01.dbf' SIZE 10G AUTOEXTEND ON NEXT 1G MAXSIZE UNLIMITED;#给用户授权
ALTER USER TEST_USER QUOTA UNLIMITED ON NEW_TBS;#检查选择的表是否可以执行在线重定义
BEGINDBMS_REDEFINITION.CAN_REDEF_TABLE('TEST_USER', 'TEST_TABLE');
END;
/#创建中间表(结构与原表一致,但指定新表空间)
CREATE TABLE test_user.test_table_int (id NUMBER PRIMARY KEY,name VARCHAR2(100) NOT NULL,created_date DATE,value NUMBER(10),comments VARCHAR2(500)
) TABLESPACE new_tbs;# 开始在线重定义(使用主键方式)
BEGINDBMS_REDEFINITION.START_REDEF_TABLE(uname => 'TEST_USER',orig_table => 'TEST_TABLE',int_table => 'TEST_TABLE_INT',options_flag => DBMS_REDEFINITION.CONS_USE_PK  -- 使用主键);
END;
/# 复制依赖对象(自动复制索引、约束)
DECLAREnum_errors PLS_INTEGER;
BEGINDBMS_REDEFINITION.COPY_TABLE_DEPENDENTS(uname => 'TEST_USER',orig_table => 'TEST_TABLE',int_table => 'TEST_TABLE_INT',copy_indexes => DBMS_REDEFINITION.CONS_ORIG_PARAMS,copy_triggers => TRUE,copy_constraints => TRUE,copy_privileges => TRUE,ignore_errors => TRUE,num_errors => num_errors);
END;
/# 同步数据
BEGINDBMS_REDEFINITION.SYNC_INTERIM_TABLE(uname => 'TEST_USER',orig_table => 'TEST_TABLE',int_table => 'TEST_TABLE_INT');
END;
/# 完成重定义(短暂锁表)# DBMS_REDEFINITION.FINISH_REDEF_TABLE 会执行flush shard pool 需要规避
alter session set events '10995 trace name context forever, level 2';BEGINDBMS_REDEFINITION.FINISH_REDEF_TABLE(uname => 'TEST_USER',orig_table => 'TEST_TABLE',int_table => 'TEST_TABLE_INT');
END;
/

增加、修改或者删除表的字段

操作:添加字段new_column VARCHAR2(50),删除字段comments。

#检查选择的表是否可以执行在线重定义
BEGINDBMS_REDEFINITION.CAN_REDEF_TABLE('TEST_USER', 'TEST_TABLE');
END;
/

# 创建中间表(添加新字段,删除旧字段)
CREATE TABLE test_user.test_table_int (id NUMBER PRIMARY KEY,name VARCHAR2(100) NOT NULL,created_date DATE,value NUMBER(10),new_column VARCHAR2(50)
) TABLESPACE test_tbs;

# 开始在线重定义(使用主键方式)
BEGINDBMS_REDEFINITION.START_REDEF_TABLE(uname        => 'TEST_USER', orig_table   => 'TEST_TABLE',int_table    => 'TEST_TABLE_INT',col_mapping  => 'id id, name name, created_date created_date, value value', options_flag => DBMS_REDEFINITION.CONS_USE_PK);
END;
/

# 复制依赖对象(自动复制索引、约束)
DECLAREnum_errors PLS_INTEGER;
BEGINDBMS_REDEFINITION.COPY_TABLE_DEPENDENTS(uname => 'TEST_USER',orig_table => 'TEST_TABLE',int_table => 'TEST_TABLE_INT',copy_indexes => DBMS_REDEFINITION.CONS_ORIG_PARAMS,copy_triggers => TRUE,copy_constraints => TRUE,copy_privileges => TRUE,ignore_errors => TRUE,num_errors => num_errors);
END;
/
# 同步数据
BEGINDBMS_REDEFINITION.SYNC_INTERIM_TABLE(uname => 'TEST_USER',orig_table => 'TEST_TABLE',int_table => 'TEST_TABLE_INT');
END;
/

# 完成重定义
BEGINDBMS_REDEFINITION.FINISH_REDEF_TABLE(uname => 'TEST_USER',orig_table => 'TEST_TABLE',int_table => 'TEST_TABLE_INT');
END;
/

将非分区表转换为分区表

#检查选择的表是否可以执行在线重定义
BEGINDBMS_REDEFINITION.CAN_REDEF_TABLE('TEST_USER', 'TEST_TABLE');
END;
/

#创建中间表
CREATE TABLE test_user.test_table_int (id            NUMBER,name          VARCHAR2(100) NOT NULL,created_date  DATE NOT NULL, value         NUMBER(10),new_column    VARCHAR2(50),CONSTRAINT pk_test_table_int PRIMARY KEY (id, created_date) 
)
PARTITION BY RANGE (created_date) (PARTITION p1 VALUES LESS THAN (TO_DATE('2023-01-01', 'YYYY-MM-DD')),PARTITION p2 VALUES LESS THAN (TO_DATE('2024-01-01', 'YYYY-MM-DD')),PARTITION p3 VALUES LESS THAN (MAXVALUE)
) TABLESPACE test_tbs;

# 开始在线重定义(使用主键方式)
BEGINDBMS_REDEFINITION.START_REDEF_TABLE(uname        => 'TEST_USER',orig_table   => 'TEST_TABLE',int_table    => 'TEST_TABLE_INT',col_mapping  => 'id id, name name, created_date created_date, value value, new_column new_column',  options_flag => DBMS_REDEFINITION.CONS_USE_PK);
END;
/

-- 复制依赖对象(自动复制索引、约束)
DECLAREnum_errors PLS_INTEGER;
BEGINDBMS_REDEFINITION.COPY_TABLE_DEPENDENTS(uname => 'TEST_USER',orig_table => 'TEST_TABLE',int_table => 'TEST_TABLE_INT',copy_indexes => DBMS_REDEFINITION.CONS_ORIG_PARAMS,copy_triggers => TRUE,copy_constraints => TRUE,copy_privileges => TRUE,ignore_errors => TRUE,num_errors => num_errors);
END;
/

# 同步数据
BEGINDBMS_REDEFINITION.SYNC_INTERIM_TABLE(uname => 'TEST_USER',orig_table => 'TEST_TABLE',int_table => 'TEST_TABLE_INT');
END;
/

# 完成重定义# DBMS_REDEFINITION.FINISH_REDEF_TABLE 会执行flush shard pool 需要规避
alter session set events '10995 trace name context forever, level 2';BEGINDBMS_REDEFINITION.FINISH_REDEF_TABLE(uname => 'TEST_USER',orig_table => 'TEST_TABLE',int_table => 'TEST_TABLE_INT');
END;
/

#创建新表空间
CREATE TABLESPACE new_tbs DATAFILE '/datafile/new_tbs01.dbf' SIZE 10G AUTOEXTEND ON NEXT 1G MAXSIZE UNLIMITED;#给用户授权
ALTER USER TEST_USER QUOTA UNLIMITED ON NEW_TBS;#检查选择的表是否可以执行在线重定义
BEGINDBMS_REDEFINITION.CAN_REDEF_TABLE('TEST_USER', 'TEST_TABLE');
END;
/#创建中间表(结构与原表一致,但指定新表空间)
CREATE TABLE test_user.test_table_int (id NUMBER PRIMARY KEY,name VARCHAR2(100) NOT NULL,created_date DATE,value NUMBER(10),comments VARCHAR2(500)
) TABLESPACE new_tbs;# 开始在线重定义(使用主键方式)
BEGINDBMS_REDEFINITION.START_REDEF_TABLE(uname => 'TEST_USER',orig_table => 'TEST_TABLE',int_table => 'TEST_TABLE_INT',options_flag => DBMS_REDEFINITION.CONS_USE_PK  -- 使用主键);
END;
/-- 复制依赖对象(自动复制索引、约束)
DECLAREnum_errors PLS_INTEGER;
BEGINDBMS_REDEFINITION.COPY_TABLE_DEPENDENTS(uname => 'TEST_USER',orig_table => 'TEST_TABLE',int_table => 'TEST_TABLE_INT',copy_indexes => DBMS_REDEFINITION.CONS_ORIG_PARAMS,copy_triggers => TRUE,copy_constraints => TRUE,copy_privileges => TRUE,ignore_errors => TRUE,num_errors => num_errors);
END;
/# 同步数据
BEGINDBMS_REDEFINITION.SYNC_INTERIM_TABLE(uname => 'TEST_USER',orig_table => 'TEST_TABLE',int_table => 'TEST_TABLE_INT');
END;
/# 完成重定义(短暂锁表)# DBMS_REDEFINITION.FINISH_REDEF_TABLE 会执行flush shard pool 需要规避
alter session set events '10995 trace name context forever, level 2';BEGINDBMS_REDEFINITION.FINISH_REDEF_TABLE(uname => 'TEST_USER',orig_table => 'TEST_TABLE',int_table => 'TEST_TABLE_INT');
END;
/

修改表的分区结构

当前表为范围分区:

# 创建哈希分区中间表CREATE TABLE test_user.test_table_int (id            NUMBER,name          VARCHAR2(100) NOT NULL,created_date  DATE,value         NUMBER(10),new_column    VARCHAR2(50),CONSTRAINT pk_test_table_int PRIMARY KEY (id)
)
PARTITION BY HASH (id)
PARTITIONS 4
TABLESPACE test_tbs;

# 启动在线重定义
BEGINDBMS_REDEFINITION.START_REDEF_TABLE(uname        => 'TEST_USER',orig_table   => 'TEST_TABLE',int_table    => 'TEST_TABLE_INT',col_mapping  => 'id id, name name, created_date created_date, value value, new_column new_column',options_flag => DBMS_REDEFINITION.CONS_USE_PK);
END;
/

# 复制依赖对象(自动复制索引、触发器等)
DECLAREnum_errors PLS_INTEGER;
BEGINDBMS_REDEFINITION.COPY_TABLE_DEPENDENTS(uname          => 'TEST_USER',orig_table     => 'TEST_TABLE',int_table      => 'TEST_TABLE_INT',copy_indexes   => DBMS_REDEFINITION.CONS_ORIG_PARAMS,copy_triggers  => TRUE,ignore_errors  => TRUE,num_errors     => num_errors);DBMS_OUTPUT.PUT_LINE('依赖对象错误: ' || num_errors);
END;
/

# 同步数据
BEGINDBMS_REDEFINITION.SYNC_INTERIM_TABLE(uname        => 'TEST_USER',orig_table   => 'TEST_TABLE',int_table    => 'TEST_TABLE_INT');
END;
/

# 完成重定义(短暂锁表)
BEGINDBMS_REDEFINITION.FINISH_REDEF_TABLE(uname        => 'TEST_USER',orig_table   => 'TEST_TABLE',int_table    => 'TEST_TABLE_INT');
END;
/

高水位线回收(碎片整理)

# 记录当前高水位线
SELECT blocks, empty_blocks 
FROM dba_tables 
WHERE owner = 'TEST_USER' AND table_name = 'TEST_TABLE';

#检查选择的表是否可以执行在线重定义
BEGINDBMS_REDEFINITION.CAN_REDEF_TABLE('TEST_USER', 'TEST_TABLE');
END;
/

#创建中间表
CREATE TABLE test_user.test_table_int (id NUMBER PRIMARY KEY,name VARCHAR2(100) NOT NULL,created_date DATE,value NUMBER(10),new_column VARCHAR2(50)
) TABLESPACE test_tbs;

# 开始在线重定义(使用主键方式)
BEGINDBMS_REDEFINITION.START_REDEF_TABLE(uname        => 'TEST_USER',orig_table   => 'TEST_TABLE',int_table    => 'TEST_TABLE_INT',col_mapping  => 'id id, name name, created_date created_date, value value, new_column new_column',  options_flag => DBMS_REDEFINITION.CONS_USE_PK);
END;
/

-- 复制依赖对象(自动复制索引、约束)
DECLAREnum_errors PLS_INTEGER;
BEGINDBMS_REDEFINITION.COPY_TABLE_DEPENDENTS(uname => 'TEST_USER',orig_table => 'TEST_TABLE',int_table => 'TEST_TABLE_INT',copy_indexes => DBMS_REDEFINITION.CONS_ORIG_PARAMS,copy_triggers => TRUE,copy_constraints => TRUE,copy_privileges => TRUE,ignore_errors => TRUE,num_errors => num_errors);
END;
/

# 同步数据
BEGINDBMS_REDEFINITION.SYNC_INTERIM_TABLE(uname => 'TEST_USER',orig_table => 'TEST_TABLE',int_table => 'TEST_TABLE_INT');
END;
/

# 完成重定义# DBMS_REDEFINITION.FINISH_REDEF_TABLE 会执行flush shard pool 需要规避
alter session set events '10995 trace name context forever, level 2';BEGINDBMS_REDEFINITION.FINISH_REDEF_TABLE(uname => 'TEST_USER',orig_table => 'TEST_TABLE',int_table => 'TEST_TABLE_INT');
END;
/

检查高水位是否回收

SELECT blocks, empty_blocks 
FROM dba_tables 
WHERE owner = 'TEST_USER' AND table_name = 'TEST_TABLE';

转换为索引组织表(IOT)

总体步骤都与前面相同

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/bicheng/92060.shtml
繁体地址,请注明出处:http://hk.pswp.cn/bicheng/92060.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Web 开发 12

1 网址里的 “搜索请求” 结构 这张图是在教你怎么看懂 网址里的 “搜索请求” 结构,特别基础但超重要,对你学前端帮别人做搜索功能超有用,用大白话拆成 3 步讲: 1. 先看「协议(Protocol)」 HTTPS 就是浏…

网络安全 | 如何构建一个有效的企业安全响应团队

网络安全 | 如何构建一个有效的企业安全响应团队 一、前言 二、团队组建的基础要素 2.1 人员选拔 2.2 角色定位 三、团队应具备的核心能力 3.1 技术专长 3.2 应急处置能力 3.3 沟通协作能力 四、团队的运作机制 4.1 威胁监测与预警流程 4.2 事件响应流程 4.3 事后复盘与改进机制…

HTTP、WebSocket、TCP、Kafka等通讯渠道对比详解

在当今互联的数字世界中,通信渠道是系统、应用程序和设备之间数据交换的支柱。从传统的HTTP和TCP协议到专为特定场景设计的Kafka和MQTT等平台,这些通信方式满足了从实时消息传递到大规模数据流处理的多样化需求。本文将深入探讨主要的通信协议和平台。一…

臭氧、颗粒物和雾霾天气过程的大气污染物计算 CAMx模型

随着我国经济快速发展,我国面临着日益严重的大气污染问题。大气污染是工农业生产、生活、交通、城市化等方面人为活动的综合结果,同时气象因素是控制大气污染的关键自然因素。大气污染问题既是局部、当地的,也是区域的,甚至是全球…

数据结构(13)堆

目录 1、堆的概念与结构 2、堆的实现 2.1 向上调整算法(堆的插入) 2.2 向下调整算法(堆的删除) 2.3 完整代码 3、堆的应用 3.1 堆排序 3.2 Top-K问题 1、堆的概念与结构 堆是一种特殊的二叉树,根结点最大的堆称…

C++模板知识点3『std::initializer_list初始化时逗号表达式的执行顺序』

std::initializer_list初始化时逗号表达式的执行顺序 在使用Qt Creator4.12.2&#xff0c;Qt5.12.9 MinGW开发的过程中发现了一个奇怪的现象&#xff0c;std::initializer_list<int>在初始化构造时的执行顺序反了&#xff0c;经过一番测试发现&#xff0c;其执行顺序可正…

【Unity3D】Shader圆形弧度裁剪

片元着色器&#xff1a; float3 _Center float3(0, 0, 0); float3 modelPos i.modelPos;// float angle atan2(modelPos.y - _Center.y, modelPos.x - _Center.x); // 计算角度&#xff0c;范围-π到π float angle atan2(modelPos.y - _Center.y, modelPos.z - _Center.z)…

curl发送文件bodyParser无法获取请求体的问题分析

问题及现象 开发过程使用curlPUT方式发送少量数据, 后端使用NodeJSexpress框架bodyParser,但测试发现无法获取到请求体内容,现象表现为req.body 为空对象 {} 代码如下: const bodyParser require(body-parser); router.use(/api/1, bodyParser.raw({limit: 10mb, type: */*}))…

Vue3 学习教程,从入门到精通,Vue 3 内置属性语法知识点及案例代码(25)

Vue 3 内置属性语法知识点及案例代码 Vue 3 提供了丰富的内置属性&#xff0c;帮助开发者高效地构建用户界面。以下将详细介绍 Vue 3 的主要内置属性&#xff0c;并结合详细的案例代码进行说明。每个案例代码都包含详细的注释&#xff0c;帮助初学者更好地理解其用法。1. data …

机器学习基石:深入解析线性回归

线性回归是机器学习中最基础、最核心的算法之一&#xff0c;它为我们理解更复杂的模型奠定了基础。本文将带你全面解析线性回归的方方面面。1. 什么是回归&#xff1f; 回归分析用于预测连续型数值。它研究自变量&#xff08;特征&#xff09;与因变量&#xff08;目标&#xf…

OneCodeServer 架构深度解析:从组件设计到运行时机制

一、架构概览与设计哲学1.1 系统定位与核心价值OneCodeServer 作为 OneCode 平台的核心服务端组件&#xff0c;是连接前端设计器与后端业务逻辑的桥梁&#xff0c;提供了从元数据定义到应用程序执行的完整解决方案。它不仅是一个代码生成引擎&#xff0c;更是一个全生命周期管理…

Jwts用于创建和验证 ​​JSON Web Token(JWT)​​ 的开源库详解

Jwts用于创建和验证 ​​JSON Web Token&#xff08;JWT&#xff09;​​ 的开源库详解在 Java 开发中&#xff0c;提到 Jwts 通常指的是 ​​JJWT&#xff08;Java JWT&#xff09;库​​中的核心工具类 io.jsonwebtoken.Jwts。JJWT 是一个专门用于创建和验证 ​​JSON Web To…

如果发送的数据和接受的数据不一致时,怎么办?

那ART4222这个板卡举例&#xff0c;我之间输入一个原始数据“6C532A14”&#xff0c;但是在选择偶校验时&#xff0c;接收的是“6C532B14”&#xff0c;我发送的码率&#xff08;运行速度&#xff09;是100000&#xff0c;但接受的不稳定&#xff0c;比如&#xff1b;“100100.…

ISCC认证:可持续生产的新标杆。ISCC如何更快认证

在全球可持续发展浪潮中&#xff0c;ISCC&#xff08;国际可持续与碳认证&#xff09;体系已成为企业绿色转型的重要工具。这一国际公认的认证系统覆盖农业、林业、废弃物处理等多个领域&#xff0c;通过严格的可持续性标准、供应链可追溯性要求和碳排放计算规范&#xff0c;建…

想对学习自动化测试的一些建议

Python接口自动化测试零基础入门到精通&#xff08;2025最新版&#xff09;接触了不少同行&#xff0c;由于他们之前一直做手工测试&#xff0c;现在很迫切希望做自动化测试&#xff0c;其中不乏工作5年以上的人。 本人从事软件自动化测试已经近5年&#xff0c;从server端到web…

电子电气架构 ---智能电动汽车嵌入式软件开发过程中的block点

我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 做到欲望极简,了解自己的真实欲望,不受外在潮流的影响,不盲从,不跟风。把自己的精力全部用在自己。一是去掉多余,凡事找规律,基础是诚信;二是…

createAsyncThunk

下面&#xff0c;我们来系统的梳理关于 Redux Toolkit 异步操作&#xff1a;createAsyncThunk 的基本知识点&#xff1a;一、createAsyncThunk 概述 1.1 为什么需要 createAsyncThunk 在 Redux 中处理异步操作&#xff08;如 API 调用&#xff09;时&#xff0c;传统方法需要手…

STM32F103C8T6 BC20模块NBIOT GPS北斗模块采集温湿度和经纬度发送到EMQX

云平台配置 访问下载页面&#xff1a;免费试用 EMQX Cloud 或 EMQX Enterprise | 下载 EMQX&#xff0c;根据需求选择对应版本下载。将下载的压缩包上传至服务器&#xff08;推荐存放于C盘根目录&#xff0c;便于后续操作&#xff09;&#xff0c;并解压至指定路径&#xff08…

YOLO11涨点优化:自研检测头, 新创新点(SC_C_11Detect)检测头结构创新,实现有效涨点

目标检测领域迎来重大突破!本文揭秘原创SC_C_11Detect检测头,通过空间-通道协同优化与11层深度结构,在YOLO系列上实现mAP最高提升5.7%,小目标检测精度暴涨9.3%!创新性结构设计+即插即用特性,为工业检测、自动驾驶等场景带来革命性提升! 一、传统检测头的三大痛点 在目…

OSCP 考试期间最新考试政策

根据 Offensive Security 官方最新考试政策&#xff08;2025 年 7 月&#xff09;&#xff0c;OSCP 考试期间禁止或严格限制以下工具与行为&#xff1a; 一、绝对禁止使用的工具/服务 类别举例说明商业/付费版本Metasploit Pro、Burp Suite Pro、Cobalt Strike、Canvas、Core …