Oracle 12.2 新特性:在线的修改数据表为分区表

众所周知,分区技术是Oracle应用最为广泛的一个选件,并且历史悠久,然而在过去的版本中,如果我们要将一个现有的数据表转换为分区表,则是相当复杂的一个过程,而在 12.2 版本中,这个过程被简化为一个在线的操作。

请看以下Demo SQL语句:

CREATE TABLE sales ( order_num NUMBER, order_name VARCHAR2(128), region VARCHAR2(10)); insert into sales (1,'YHEM','BEIJING'); insert into sales (2,'ENMOTECH','SHENZHEN'); insert into sales (3,'YHEM','SHANGHAI'); ALTER TABLE sales MODIFY PARTITION BY LIST (region) (partition p1 values ('BEIJING'), partition p2 values ('SHENZHEN'), partition p3 values ('SHANGHAI'), partition p4 values (DEFAULT)) ONLINE;

在Modify修改表结构时,增加了ONLINE语句,可以直接将原有的数据表修改为分区结构。不会影响现有业务的运行。

在Live SQL站点运行一下测试语句( https://livesql.oracle.com ),可以看到顺利的完成了分区定义。事实上这个功能已经非常健壮:

那么Oracle在后台是如何完成这个DDL的重定义过程呢?

如果通过10046进行跟踪,可以发现这是一个非常复杂的内部递归过程,Oracle会建立一个日志表记录变更,然后通过Bulk Move批量迁移原有数据,最后增量应用变化数据,所以当然,你会发现这期间需要两倍的存储空间:

10046 的跟踪日志,揭示了这一过程,以下是跟踪日志中一个映射表的建立(感兴趣的同学可以从10046中找到很多原理性知识):

一个简单的操作,后台的递归执行高达2500次,大家可以想象Oracle这艘航空母舰有多么的庞大:

体验12.2,学习不止步!

原文发布于微信公众号 - 数据和云(OraNews)

原文发表时间:2017-01-04

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

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏杨建荣的学习笔记

通过shell脚本监控日志切换频率 (94天)

在数据库遇到性能问题的时候,可能从io,cpu等角度能够下手找到性能瓶颈,日志的切换也是影响性能的一个因素,如果日志切换台频繁,等待时间就会在日志相关的事件上,...

2708
来自专栏Albert陈凯

2018-09-10 MariaDB和MySQL全面对比:选择数据库需要考虑这几点

http://www.infoq.com/cn/articles/mariadb-vs-mysql

393
来自专栏区块链入门

第十五课 手把手教你以太坊ENS域名注册,抢做一个3000万的发财梦!

【本文目标】 通过本文学习,可以抢注ENS域名,便于后续增值和转账使用。 【前置条件】 本文无技术前置条件,但是需要有超过0.05个ETH的以太坊地址。 ...

603
来自专栏FreeBuf

思科设备存在硬编码密码,安全更新第四次删除后门账户

近几个月,思科已经第四次删除了存在于其产品中的硬编码密码,攻击者可以使用这些证书来获取设备的访问权限,并存在于用户网络中。

830
来自专栏VMCloud

【解析向】腾讯云的Windows Server日志配置收集工具是个什么鬼?(2)

继上一篇,上一篇重点介绍了腾讯云Windows Server日志收集工具的“场景”功能,那么场景功能究竟是以什么标准来分级的呢?

3477
来自专栏极客慕白的成长之路

CTF线下防御战 — 让你的靶机变成“铜墙铁壁”

随着CTF的普及,比赛的形式也有了越来越多的花样,对于线下赛来说,开始出现了安全加固或者防御战之类的环节,亦或者因为拿下靶机后不希望其他攻击者进入而进行“争夺”...

1074
来自专栏CDA数据分析师

海纳百川 有容乃大:SparkR与Docker的机器学习实战

? 题图为美国尼米兹核动力航空母舰 介 绍 大数据时代,我们常常面对海量数据而头疼。作为学统计出身的人,我们想折腾大数据但又不想学习Hadoop或者Java,...

1846
来自专栏VMCloud

【腾讯云的1001种玩法】在腾讯云上创建您的 SQL Server 故障转移集群(5)

https://cloud.tencent.com/document/product/215/18025

4160
来自专栏MYSQL轻松学

MySQL高可用性解决方案—Percona XtraDB Cluster

MySQL的历史演变: 1985 年,瑞典的几位志同道合小伙子成立了一家公司,这就是MySQL AB 的前身 1996年年初,MySQL 1.0发布 1996年...

4525
来自专栏杨建荣的学习笔记

Oracle 12.1升级到12.2的两种方法(r12笔记第92天)

自Oracle 12.2发布以来,就会面临两类升级的需求,一类是12.1升级到12.2,毕竟12.1和12.2的发布时间间隔有5年左右的时间,这个时间段内已...

3435

扫描关注云+社区