当前位置: 首页 > news >正文

Oracle 的 MOVE 操作是否重建表?

Oracle 的 MOVE 操作是否重建表?

Oracle 的 ALTER TABLE ... MOVE 操作实质上是重建表的物理存储结构,但保留表的逻辑定义不变。

MOVE 操作的本质

  1. 物理重建

    • 创建新的数据段(物理存储结构)
    • 将原表数据按顺序重新插入到新段中
    • 删除原数据段
    • 更新数据字典指向新段
  2. 逻辑不变

    • 表名、列定义、约束等逻辑结构保持不变
    • 表的对象ID(OBJECT_ID)会发生变化
    • 依赖对象(如视图、同义词)不受影响

重建的具体表现

  1. 数据重组
    -- 执行前数据块状态
    SELECT extent_id, block_id, blocks 
    FROM dba_extents 
    WHERE segment_name = 'YOUR_TABLE';-- 执行MOVE
    ALTER TABLE your_table MOVE;-- 执行后数据块状态(完全改变)
    

输出示例:

SQL> SELECT extent_id, block_id, blocks FROM dba_extents WHERE segment_name = 'T1' and OWNER='TEST';EXTENT_ID   BLOCK_ID     BLOCKS
---------- ---------- ----------0       2496          81       4696          82       4704          83       4712          84       4720          85       4728          86       6016          87       6024          88       6032          89       6040          810       6048          811       6056          812       6064          813       6072          814       6080          815       6088          816       6272        12817       6400        12818       6528        12819       6656        12820       6784        12821       6912        12822       7040        12823       7168        12824       7296        12825       7424        12826       7552        12827 rows selected.SQL> ALTER TABLE t1 MOVE;Table altered.SQL> SELECT extent_id, block_id, blocks FROM dba_extents WHERE segment_name = 'T1' and OWNER='TEST';EXTENT_ID   BLOCK_ID     BLOCKS
---------- ---------- ----------0      10080          81      10088          82      10096          83      10104          84      10240          85      10248          86      10256          87      10264          88      10272          89      10280          810      10288          811      10296          812      10304          813      10312          814      10320          815      10328          816      10368        12817      10496        12818      10624        12819      10752        12820      10880        12821      11008        12822      11136        12823      14336        12824      14464        12825      14592        12826      14720        12827 rows selected.
  1. DATA_OBJECT_ID变化
    -- 执行前
    

select object_id,data_object_id,object_name,to_char(created,‘yyyy-mm-dd hh24:mi:ss’) created from dba_objects where object_name = ‘T1’ and owner=‘TEST’ ;

– 执行后(新DATA_OBJECT_ID)


输出示例:```sql
SQL> select object_id,data_object_id ,object_name,to_char(created,'yyyy-mm-dd hh24:mi:ss') created from dba_objects where object_name = 'T1' and owner='TEST' ;OBJECT_ID DATA_OBJECT_ID OBJECT_NAME     CREATED
---------- -------------- --------------- -------------------75061          75870 T1              2025-02-04 23:15:05SQL> ALTER TABLE t1 MOVE;Table altered.SQL> select object_id,data_object_id ,object_name,to_char(created,'yyyy-mm-dd hh24:mi:ss') created from dba_objects where object_name = 'T1' and owner='TEST' ;OBJECT_ID DATA_OBJECT_ID OBJECT_NAME     CREATED
---------- -------------- --------------- -------------------75061          75871 T1              2025-02-04 23:15:05
  1. ROWID变化
    • 所有行的ROWID都会改变
    • 基于ROWID的应用程序需要调整

与真正"重建表"的区别

特性MOVE操作完全重建表(CREATE AS SELECT)
表定义保留所有属性需要手动重建约束、触发器等
对象依赖关系自动保持需要手动重建
权限保留原有权限需要重新授权
执行速度较快较慢
高水位线重置完全重置完全重置
索引状态需要重建需要重建

需要特别注意的影响

  1. 索引处理

    -- MOVE后必须重建索引
    ALTER INDEX your_index REBUILD;
  2. 依赖对象

    • 物化视图日志会被清除
    • 基于ROWID的物化视图需要刷新
    • 某些类型的约束可能需要重新验证
  3. 在线操作限制

    -- 12C开始支持有限制的在线MOVE
    ALTER TABLE your_table MOVE ONLINE;
    -- 但仍有部分锁限制,可能阻塞DML
    

何时应该使用MOVE

  1. 典型场景

    • 表碎片化严重(超过30%空闲空间)
    • 需要迁移到其他表空间
    • 需要改变存储参数(如压缩)
    • 高水位线远高于实际数据位置
  2. 替代方案比较

    • 对于小型表:CREATE TABLE new_table AS SELECT * FROM old_table
    • 对于最小化停机:DBMS_REDEFINITION在线重定义
    • 对于部分优化:SHRINK SPACE(不改变ROWID)

MOVE操作是Oracle提供的一种高效的"表重建"机制,它在保持逻辑结构不变的前提下,完全重建表的物理存储结构,是维护Oracle数据库性能的重要工具。

相关文章:

  • springboot配置redis lettuce连接池,以及连接池参数解释
  • 从逻辑学视角严谨证明数据加密的数学方法与实践
  • 【Ubuntu】如何在一个脚本文件中跑三个python文件?以及端口被占的解决方法
  • 企业级云原生爬虫架构与智能优化
  • ArcGIS Pro 3.4 二次开发 - 地理数据库
  • PostgreSQL 数据库备份与恢复
  • 从源码编译支持ffmpeg(H264编码)的opencv(创建mp4视频报错:H264 is not supported with codec id 28)
  • Oracle 基础知识作业的使用
  • Linux-线程同步于互斥
  • Docker Volumes 还原指南
  • 超详细openBmc Virtual Media 功能及实现流程(1)
  • 使用Rancher在CentOS 环境上部署和管理多Kubernetes集群
  • nginx配置跨域请求,后台不用配置啦,完美
  • VMware虚拟机突然无法ssh连接
  • 消除爆红 [vue/no-unused-vars] ‘row‘ is defined but never used.eslint-plugin-vue
  • 【NGINX】-11 nginx 平滑升级
  • 如何使用patch-package给npm包打补丁
  • halcon 连接相机
  • 扫描电镜:打开微观世界的“超维相机“
  • 晶圆隐裂检测提高半导体行业效率
  • 怎么建一个小说网站/百度手机助手下载安装最新版
  • 如何做优秀的视频网站设计/网站制作详细流程
  • 北京个人做网站/百度小程序优化排名
  • 免费建设淘宝客网站/做企业推广的公司
  • 生物医药网站建设/宁波seo排名优化
  • 免费功能网站/hao123影视