Oracle数据表默认值列添加与行迁移(Row Migration)

在笔者之前的文章中,已经探讨过给一个数据表添加默认值列是一项非常危险的事情,特别是在在线生产环境下。给一张大数据表添加有默认值列,最直接的有下面几个严重危害: 系统高负荷运行,消耗大量资源。添加列操作是一次性的DDL操作,生成大量的Redo Log记

在笔者之前的文章中,已经探讨过给一个数据表添加有默认值列是一项非常“危险”的事情,特别是在在线生产环境下。给一张大数据表添加有默认值列,最直接的有下面几个严重危害:

系统高负荷运行,消耗大量资源。添加列操作是一次性的DDL操作,生成大量的Redo Log记录;
长期数据表锁定,阻碍生产系统作业。添加数据列期间,对数据表添加独占锁,此时阻碍其他DML操作;
破坏原有存储结构,造成大量的行迁移Row Migration)数据。在每个数据行尝试添加进默认值,进行膨胀的同时,由于rowid的特性,会引起严重的行链接情况,损害原有数据表存储结构;

本文主要想聊聊由于默认值添加带来的行链接(Row Migration)现象。

1、从Row Migration现象谈起

Row Migration本质上是一种由于Oracle存储特性和数据行定位特性而发生的一种现象。在Oracle中,所有的数据行都是保留在数据块单元上的。一个数据块可以容纳若干条数据(通常条件下)。一些数据列,如varchar2类型,大部分情况下都是根据输入数据的长度进行空间分配。

那么,如果数据行列填入了更大的数据,也就是空间发生了拓展。数据块存储上就会发生何种变化呢?每个数据块都会预留一部分的空闲空间,作为数据行变化预留位置。如果长度继续拓展,那么会发生什么呢?

Oracle会尝试将这个数据行拷贝出,找个新的数据块进行存储。这样,就可以放下数据块。那么,一个新的问题出现了,就是Rowid问题。

在Oracle中,Rowid是定位一条记录的物理地址。Rowid包括数据文件相对编号、对象号、数据块号和Slot行号。Rowid普遍作为数据行的标记,保存在相关的索引叶子节点上。但是,当一个数据行被转移存储到另一个数据块,本质上物理存储位置已经发生变化。索引等对象中包括的Rowid面临着失效的问题。

Oracle解决这个问题是通过“虚拟门牌”的方法。这个数据行位置虽然已经到另外的地方,但是对应的Rowid并没有发生变化。当我们检索数据,Server Process定位到原来的位置时,它会找到一个转换跳转地址,那里面记录着真正的Rowid地址。这个就是发生了Row Migration。

Row Migration给系统性能带来了很多潜在的问题。比如,一行数据原来只需要寻找一个数据块记录,现在就需要寻找多个数据块才可以。这样就是带来的性能问题。

我们在进行默认值数据行添加的时候,就会带来Row Migration的爆发。

2、Row Migration与默认值列添加

下面我们通过实验,来证明Row Migration的出现。我们选择11gR2环境进行实验。

SQL> select * from v$version;

BANNER
——————————————————————————–
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 – Production
PL/SQL Release 11.2.0.1.0 – Production
CORE       11.2.0.1.0        Production

SQL> create table t as select object_id from dba_objects where 1=0;
Table created

–添加若干条记录;
SQL> insert into t select object_id from dba_objects where rownum
99 rows inserted

SQL> commit;
Commit complete

数据表T,在存储结构和空间分配上情况如下:

SQL> exec dbms_stats.gather_table_stats(user,’T’,cascade => true);
PL/SQL procedure successfully completed

SQL> select bytes, blocks,extents from user_segments where segment_name=’T’;

    BYTES    BLOCKS   EXTENTS
———- ———- ———-
    65536         8         1

SQL> select blocks from user_tables where table_name=’T’;

   BLOCKS
———-
        1

User_segment中记录着给数据段分配的总空间,但这并不代表全部的HWM位置。User_tables中的blocks,才代表HWM下数据块的个数。从上面的结果看,HWM下一共只有一个数据块。从rowid分析看,实际也的确如此。

SQL> select dbms_rowid.rowid_block_number(rowid) blockno, count(*) from t group by dbms_rowid.rowid_block_number(rowid);

  BLOCKNO  COUNT(*)
———- ———-
    85857        99

下面我们进行数据列添加。

SQL> alter table t add vc varchar2(1000) default lpad(‘T’,500,’T’);
Table altered

Executed in 0.078 seconds

对应的空间使用情况如下:

SQL> exec dbms_stats.gather_table_stats(user,’T’,cascade => true);
PL/SQL procedure successfully completed

Executed in 0.141 seconds

SQL> select blocks from user_tables where table_name=’T’;

   BLOCKS
———-
       12

Executed in 0.016 seconds

SQL> select bytes, blocks,extents from user_segments where segment_name=’T’;

    BYTES    BLOCKS   EXTENTS
———- ———- ———-
   131072        16         2

SQL> select dbms_rowid.rowid_block_number(rowid) blockno, count(*) from t group by dbms_rowid.rowid_block_number(rowid);

  BLOCKNO  COUNT(*)
———- ———-
    85857        99

Executed in 0.016 seconds

上面的情况可以看出,Oracle的数据表T已经推高了水位线HWM到12个块,从空间分配也分配了新的extent使用。

但是,所有数据行rowid没有变化。所有数据行的“门牌号”都没有变化,但是存储呢?很诡异的增加了。正常容量下,数据块情况应该是如下:

SQL> create table t_bak as select * from t;

Table created

SQL> exec dbms_stats.gather_table_stats(user,’T_BAK’,cascade => true);

PL/SQL procedure successfully completed

SQL> select bytes, blocks,extents from user_segments where segment_name=’T_BAK’;

    BYTES    BLOCKS   EXTENTS
———- ———- ———-
   131072        16         2

SQL> select blocks from user_tables where table_name=’T_BAK’;

   BLOCKS
———-
        8

SQL> select dbms_rowid.rowid_block_number(rowid) blockno, count(*) from t_bak group by dbms_rowid.rowid_block_number(rowid);

  BLOCKNO  COUNT(*)
———- ———-
    86589        14
    86588        14
    86585        14
    86586        14
    86591        14
    86590        14
    86587        14
    86592         1

8 rows selected

下面,我们来证明发生了行链接情况。

3、数据表行链接检验

Analyze语句一度是非常流行的收集数据表统计量的操作方式。但是随着dbms_stats包的成熟推广,analyze在统计量收集方面的功能已经渐渐弱化。但是,Oracle依然保留了这个语句的两个基本功能:对数据表进行行链接(Row Migration)检测和索引健康程度检测。

下面使用analyze语句进行数据表T的检测。首先我们需要创建分析结果的容纳数据表。

–调用Oracle_HOME下的脚本;
SQL>@?/rdbms/admin/utlchain.sql

Table created.

SQL> desc chained_rows;
Name                                     Null?   Type
—————————————– ——– —————————-
OWNER_NAME                                        VARCHAR2(30)
TABLE_NAME                                        VARCHAR2(30)
CLUSTER_NAME                                      VARCHAR2(30)
PARTITION_NAME                                    VARCHAR2(30)
SUBPARTITION_NAME                                 VARCHAR2(30)
HEAD_ROWID                                        ROWID
ANALYZE_TIMESTAMP                                 DATE

SQL> create public synonym chained_rows for chained_rows;

Synonym created.

SQL> grant all on chained_rows to public;

Grant succeeded.

分析数据表,如下:

–检验数据行Row Migration情况;
SQL> analyze table t list chained rows into chained_rows;
Table analyzed

Executed in 0.125 seconds

–发生Row Migration次数;
SQL> select count(*) from chained_rows;

COUNT(*)
———-
       86

Executed in 0.016 seconds

SQL> select head_rowid from chained_rows where rownum

HEAD_ROWID
——————
AAASUCAABAAAU9hAAN
AAASUCAABAAAU9hAAO
AAASUCAABAAAU9hAAP
AAASUCAABAAAU9hAAQ

Executed in 0.016 seconds

SQL> select * from t where rowid=’AAASUCAABAAAU9hAAQ’;

OBJECT_ID VC
———- ——————————————————————————–
       38 TTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTT

Executed in 0.016 seconds

在99行记录中,发生了86次行链接Row Migration情况。

4、结论

解决Oracle Row Migration的方法,就是进行数据表重构,重新对存储结构和Rowid进行整理。我们说,在生产环境下,进行有默认值数据列的添加操作,会引起一系列的问题,要三思而行。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/467033.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月8日 05:50:49
下一篇 2025年11月8日 05:54:18

相关推荐

  • HOME、RESOLV、HUMA:谁会是下一个百倍币?前景与风险评估

    HOME、RESOLV和HUMA是三个具有增长潜力的数字资产项目,分别聚焦于Solana生态域名服务、DeFi收益流动性解决方案和真实世界资产代币化。1. HOME作为Solana生态的去中心化域名服务,具备生态系统刚需、网络效应和空投预期三大优势,但也面临生态依赖性高、内部竞争和价值捕获模型受限等…

    2025年12月8日
    000
  • 以太坊合约永续是什么

    以太坊合约永续是一种基于以太坊的去中心化金融衍生品,允许用户进行无到期日的杠杆多空交易。其核心特点包括:1. 无到期日,可无限期持仓;2. 资金费率机制确保价格锚定现货市场;3. 基于DEX运行,资产由用户掌控;4. 支持高杠杆交易;5. 无需托管,降低中心化风险。运作上依赖预言机获取价格、采用超额…

    2025年12月8日
    000
  • LayerZero与Wormhole争霸跨链通信赛道,谁将成为Web3桥梁之王?

    本文将深入探讨两大主流跨链通信协议——LayerZero与Wormhole。通过剖析它们的技术架构、安全模型和生态系统,我们将对比分析两者的核心差异,并探讨在激烈的Web3跨链赛道竞争中,谁更有可能成为未来的领导者,从而解答标题中关于“谁将成为Web3桥梁之王”的问题。 2025主流加密货币交易所官…

    2025年12月8日
    000
  • Aster是什么?币安领投的去中心化永续合约交易所(Perp DEX)

    目录 什么是Aster?Aster 如何工作?Aster 产品AsterEX – Perp DEX 交易所Aster Earn – 优化资产收益USDF – USDT 支持的稳定币Aster 的突出特点 AST代币和代币经济学概述Aster​​​​​​​路线图Aster项目团队、投资者和合作伙伴项目…

    2025年12月8日 好文分享
    000
  • 跨链桥是什么 跨链桥的原理

    跨链桥是解决不同区块链孤岛效应的技术工具,其核心原理通过锁定原链资产、生成映射资产实现跨链流通。1. 跨链桥的基本逻辑分为三步:锁定原链资产、在目标链生成等价映射资产、反向解锁释放资产;2. 信任机制分为三类:中心化跨链桥依赖第三方机构,效率高但存在单点故障风险;去中心化跨链桥通过节点共识验证,安全…

    2025年12月8日
    000
  • 以太坊上有哪些知名的跨链桥项目?

    以太坊上有多个知名跨链桥项目,各具特色。1. Crosser:基于零知识技术,专为 Layer 2 性能优化,支持 Optimism、Arbitrum 等网络,具备快速、安全、低手续费及交易私密性;2. Synapse Protocol:去中心化跨链桥,简化区块链间资产流动,支持多种 Layer 1…

    2025年12月8日
    000
  • 智能合约风险vs平台跑路,如何平衡收益与风险?

    在数字资产和区块链的世界里,潜在的高收益总是伴随着显著的风险。投资者在追求回报的同时,必须清醒地认识并应对这些风险。其中两大类风险尤为突出:一类是技术层面的智能合约风险,另一类是操作及信任层面的平台风险,后者有时表现为平台运营者“跑路”。理解并平衡这两类风险,是数字资产投资中的重要课题。 智能合约中…

    2025年12月8日
    000
  • 区块链预言机有啥用?为什么需要链外数据?预言机工作原理

    区块链技术的核心在于其去中心化与不可篡改的特性,这使得链上的交易和状态变更具有极高的安全性和透明度。然而,区块链的天然环境是隔离的,它无法直接访问外部世界的信息。 智能合约是运行在区块链上的自动化合约代码,它们的执行通常需要依赖特定的条件。这些条件可能与链上的事件有关,比如某个代币的转移或特定地址的…

    2025年12月8日
    000
  • 币安领投的Bedrock(BR)币是什么?BR币怎么买及价格预测

    目录 Bedrock(BR)是什么?Bedrock 项目背景Bedrock 的运作原理BR币是什么?BR代币经济学BR币价格走势分析BR币价格预测(2025–2030)1、PricePrediction.net 2、DigitalCoinPrice3、CoinDataFlow4、ExolixBedr…

    2025年12月8日 好文分享
    000
  • 数字黄金稳定币是什么?如何确保与黄金价格挂钩

    数字黄金稳定币通过实物黄金储备、独立审计、保管安全、铸造销毁、市场套利和价格预言机六项机制确保与黄金价格挂钩。1、每个代币对应特定重量的实物黄金;2、定期第三方审计保障透明度;3、专业机构保管降低风险;4、用户购买时铸造代币,赎回时销毁;5、市场套利自动纠正价格偏差;6、价格预言机提供实时金价数据,…

    2025年12月8日
    000
  • Impossible Cloud Network(ICNT)是什么?怎么样?币安即将上线项目ICN全面介绍

    目录 一、ICN是什么?二、ICNT最新动态三、ICN与其他DePIN项目的对比及经济模型四、DePIN 赛道的下一阶段展望结语 5月底,icn(impossible cloud network)@icn_protocol 宣布获得 ngp capital 战略投资,估值达到 4.7 亿美元,很多人…

    2025年12月8日
    000
  • Fragmetric(FRAG)是什么?怎么样?FRAG代币经济与未来前景分析

    目录 什么是 Fragmetric (FRAG)?Fragmetric 与 FRAG 代币的区别Fragmetric 解决了哪些问题?1. 传统 Staking 的资金效率低下2. 网络安全碎片化3. 复杂的产量优化4. DeFi 中的社区治理有限Fragmetric 的历史和背景Fragmetri…

    2025年12月8日 好文分享
    000
  • 链上股票是什么 链上股票概念加密货币有哪些

    链上股票是通过区块链技术将传统股票转化为加密代币的创新形式,1.其核心优势包括全球可及性、全天候交易、碎片化所有权和可组合性;2.主要风险涉及监管不确定性、价格脱锚风险和协议风险;3.代表性项目有Synthetix(SNX)、Mirror Protocol(MIR)、UMA(UMA)和Deus Fi…

    2025年12月8日
    000
  • 以太坊跨链桥是什么?如何实现资产转移?

    区块链技术催生了众多独立的网络,如以太坊、币安智能链、polygon等。每个网络都有其独特的设计和协议。然而,这种独立性也带来了资产和信息难以在不同链之间自由流动的挑战。例如,以太坊上的erc-20代币无法直接在polygon网络上使用。为了解决这个隔离问题,跨链桥应运而生,成为连接不同区块链网络的…

    2025年12月8日
    000
  • CESS Network是什么?怎么样?CESS币项目介绍与投资价值分析

    目录 CESS币最新新闻CESS Network项目介绍开创去中心化云存储无与伦比的性能和合乎道德的AI 集成阶层系统架构实际应用和用例为什么选择CESS Network?CESS 代币经济学最后的思考常见问题 在不断发展的区块链技术世界中,数据管理已成为一项重大挑战,推动了对去中心化、可扩展和安全…

    2025年12月8日
    000
  • CETUS协议:使用创新的架构和代币学乘坐Sui Defi浪潮

    深入了解cetus协议的架构、代币经济及其在构建sui defi生态中的关键作用。探索其前沿特性与未来潜力。 CETUS协议正在重塑SUI DeFi格局!本文深入剖析了Cetus的技术架构、代币机制及其日益增强的影响力。准备好见证Cetus如何推动SUI去中心化金融的未来发展。 CETUS协议:SU…

    2025年12月8日
    000
  • MOCA链:革新数字身份和分散隐私

    探索moca链如何以分散隐私和用户数据控制为核心,重塑数字身份体系。 MOCA链:重构数字身份与隐私保护的新范式 在数据安全日益受到重视的今天,MOCA链应运而生,成为解决用户隐私问题的关键力量。这条Layer 1区块链致力于让用户掌握自己的数字身份,同时实现真正的去中心化隐私管理。接下来,我们将深…

    2025年12月8日
    000
  • SPK币是什么?Spark 的治理结构、依赖与风险介绍

    在前两篇中,我们已经理解了 spark 的产品结构与空投机制,但一个 defi 项目能否真正走远,关键还在于它背后的人与权力——治理架构是否健康?资金机制是否透明?依赖路径是否安全可控? 今天这篇文章,我们就来完整拆解 Spark 的治理结构、与 MakerDAO 的深度绑定关系,以及可能面临的结构…

    2025年12月8日
    000
  • 什么是Mira?Mira功能、团队、未来、路线图介绍

    什么是mira?mira有什么作用?2025 mira发展路线图是什么? 近年来,生成式人工智能的快速发展对基础设施和工作流程提出了新的要求,特别是在验证和评估方面。 Mira正在构建一个创新的第1层网络,为AI输出提供无需信任、可扩展且准确的验证。通过将复杂的AI输出分解为更小的可验证部分,并利用…

    2025年12月8日 好文分享
    000
  • 顶级RWA加密项目将于2025年观看

    本文探讨,列出和审查了最佳的rwa加密投资,这些投资可能在2025年提供超大的回报。 迫切需要弥合传统金融与区块链技术之间差距的努力为新的创新浪潮打开了大门,令牌化是最新的。 该概念本身(令牌化)与将物理和传统金融资产转换为区块链的数字代币有关。 在太长时间以来,由于高入境成本,地理限制和流动性问题…

    2025年12月8日
    000

发表回复

登录后才能评论
关注微信