我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Oracle数据库中怎么实现数据行迁移与行链接

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Oracle数据库中怎么实现数据行迁移与行链接

本篇内容主要讲解“Oracle数据库中怎么实现数据行迁移与行链接”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Oracle数据库中怎么实现数据行迁移与行链接”吧!

在Oracle数据库中存在两种数据存储现象:行迁移和行链接。这两者现象严重时都会导致数据库查询性能严重低下,处理好数据存储的行链接或者行迁移也是有效提升数据库性能的有效方式。

一、行迁移和行链接的定义:

1.行迁移:
ORACLE一个BLOCK的DEFAULT SIZE是8K,事实上,一个BLOCK不可以存储8K的数据.一个BLOCK可以存储多少数据,由PCTFREE,PCTUSED参数控制(对于以前的手工管理的表空间而言).

PCTFREE:是指BLOCK保留空闲空间的百分比,用于UPDATE。对于已经插入到BLOCK的行而言,后面的UPDATE操作有可能使行的长度增加;PCTFREE就是用于容纳增加的那部分长度而保留的空闲空间。如果UPDATE时PCTFREE再也不能够容纳行增加的长度,则ORACLE会将整个行迁移到一个新的BLOCK,行的ROWID保留(不是太明白为什么ORACLE不改变ROWID),原来的BLOCK有一个指针指向ROW存放的新BLOCK。这就是行迁移。

可见,行迁移是由于UPDATE操作所导致。从字面上理解,所谓迁移,肯定先有存在这一行,才能叫着迁移.

2.行链接:
是指一个BLOCK不能容纳一行(行的长度太大),而必须将此行存放于几个BLOCK.行链接一般是在Insert时产生的.一个BLOCK能否用于insert是由PCTUSED控制.

PCTUSED:是指BLOCK用于INSERT的百分比。对于INSERT操作,BLOCK可用于容纳新行的最大空间为Blocksize-pctfree-overhead.当BLOCK数据存储已高于PCTUSED,ORACLE会将该块从自由链表中移除,直到该块已使用空间降到PCTUSED以下,才会再次将此块重新加入到Freelist(这是ORACLE以前手工管理的表空间管理空闲块的原理,现在ORACLE推荐使用ASSM).

对表分析后检查表中行迁移的情况:

select TABLE_NAME,NUM_ROWS,AVG_ROW_LEN,BLOCKS,EMPTY_BLOCKS,CHAIN_CNT from user_tables where table_name='EMP';

(其中字段CHAIN_CNT显示的就是行迁移或者行链接的表中的行数)

二、行迁移与行链接的分析检测:

检测表中是否存在行迁移或者行链接需要对表进行分析:
表分析的方法有两种:

1, analyze table emp compute statistics;2, exec dbms_stats.gather_schema_stats('scott','emp');   --前者为用户名,后者为表名

但是ORACLE的dbms_stats.gather_schema_stats只会收集优化器统计信息,不会检测表的记录是否存在行迁移和行链接,因此要分析行链接或者行迁移必须用analyse命令。

行迁移和行链接的检测:

select b.NAME,a.VALUE from v$mystat a,v$statname b where a.STATISTIC#=b.STATISTIC# and b.NAME like 'table fetch continued row';

当有返回值时,可以知道表的数据存在行迁移和行链接。
行迁移和行链接的清除:
能过REBUILD数据来清除行迁移:

create table MM_PM_temp as select * from MM_PM; truncate table MM_PM; insert into MM_PM select * from MM_PM_temp

再重新分析表:

analyze table MM_PM compute statistics;

分析过后再查看:

select t.table_name, t.num_rows, t.chain_cnt, t.avg_row_len, round((t.chain_cnt / t.num_rows) * 100, 2) as "chained rows %" from user_tables t where t.chain_cnt > 0;

如果该表的chain_cnt变为0时,表示原先的chain_cnt全部是行迁移,而不是行链接。
如果REBUILD数据后chain_cnt变少,但还大于0,则可以证明,这个表即包含行迁移,又包含真正的行链接。

事实证明,行迁移是可以通过REBUILD数据和增加PCTFREE%来清除和减少发生频率的。

注意,对于ASSM,PCTUSED,FREELIST,FREELIST GROUPS参数会被忽略。
但对于真正的行链接,只能通过将表移植到大的BLOCSIZE的表空间上。

例如:

创建一个16K的表空间:

CREATE TABLESPACE LARGETBS BLOCKSIZE 16 K LOGGING DATAFILE '/data/app/oracle/oradata/ora33/LARGETBS_01.dbf' SIZE 64M AUTOEXTEND ON NEXT 10M MAXSIZE UNLIMITED EXTENT MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT AUTO ;

在创建的时候报了个ORA-的错,原因我们没有设定16的DB_Buffer_cache,我们设定一下:

 alter system set db_16k_cache_size=34603008;

将表MOVE到16K的表空间:

 alter table class="lazy" data-src_CS move tablespace LARGETBS;
 alter table MM_PM move tablespace LARGETBS;

由于进行了迁移,表的索引会失效,所以我们要REBUILD索引:

 alter index PK_class="lazy" data-src_CS rebuild; alter index PK_MM_PM rebuild;

再重新分析:

 analyze table class="lazy" data-src_CS compute statistics; analyze table MM_PM compute statistics;

重新查询:

 select t.table_name, t.num_rows, t.chain_cnt, t.avg_row_len, round((t.chain_cnt / t.num_rows) * 100, 2) as "chained rows %" from user_tables t where t.chain_cnt > 0 order by t.table_name;

发现,这些表都没有ROW CHAIN了。可见,MOVE到16K的表空间可以清除ROW CHAIN。

三、消除迁移的方法:

一:生成一张表(chained_rows),保存迁移的行的rowid

@?/rdbms/admin/utlchain

使用分析命令将产生迁移的行的rowid插入到chained_rows表:

analyze table test01 list chained rows into chained_rows;create table tmp as select * from test01 where rowid in (select head_rowid from chained_rows);delete test01 where rowid in (select head_rowid from chained_rows);insert into test01 select * from tmp;drop table tmp purge;

再分析表:

analyze table test01 compute statistics;

再查看字典中的统计信息:

select TABLE_NAME,NUM_ROWS,AVG_ROW_LEN,BLOCKS,EMPTY_BLOCKS,CHAIN_CNT from user_tables where table_name='TEST01';

二、将存在行迁移的表用导出工具导出数据库,将原表truncate后,再讲数据重新导入。

到此,相信大家对“Oracle数据库中怎么实现数据行迁移与行链接”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Oracle数据库中怎么实现数据行迁移与行链接

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

oracle数据库怎么迁移

oracle 数据库迁移是一个涉及评估、数据迁移、架构转移、验证和切换等步骤的多项任务。选择合适的工具并制定详细计划至关重要,测试和验证确保迁移的成功,请联系专业人士以获得支持。Oracle数据库迁移如何进行Oracle数据库迁移?Or
oracle数据库怎么迁移
2024-05-30

SQLServer中怎么进行数据迁移

在SQL Server中进行数据迁移可以通过多种方法实现,以下是一些常用的方法:使用SQL Server自带的导入导出工具:SQL Server Management Studio (SSMS)提供了数据导入导出向导,可以方便地将数据从一个
SQLServer中怎么进行数据迁移
2024-03-11

oracle怎么做数据库迁移

oracle 数据库迁移涉及六个步骤:准备源数据库并创建临时表空间。创建结构相似的目标数据库并分配权限。使用数据泵导出和导入数据。验证数据并调整数据类型和约束。重新创建索引和约束并优化目标数据库。切换到目标数据库并验证连接性和数据可用性。如
oracle怎么做数据库迁移
2024-05-21

使用ODBC连接Oracle进行大数据迁移

大数据迁移是一个复杂的过程,特别是当涉及到使用ODBC连接Oracle数据库时。以下是一些步骤和注意事项:确保你已经安装了适当的ODBC驱动程序,以便连接Oracle数据库。你可以从Oracle官方网站下载适用于你的操作系统的驱动程序。配置
使用ODBC连接Oracle进行大数据迁移
2024-07-15

在Oracle中如何执行数据库升级和迁移

在Oracle数据库中,执行数据库升级和迁移通常涉及以下步骤:创建数据库备份:在进行升级或迁移之前,首先应该创建数据库的完整备份,以防止数据丢失或损坏。升级数据库软件:如果需要升级数据库软件版本,应该按照Oracle官方文档提供的步骤进行操
在Oracle中如何执行数据库升级和迁移
2024-04-09

oracle数据库怎么迁移到另一个数据库

Oracle数据库迁移到另一个数据库通常需要使用数据迁移工具或者手动迁移的方式。下面是一些迁移Oracle数据库的常用方法:使用Oracle Data Pump导出和导入数据:使用expdp命令将源数据库中的数据导出到一个数据文件中:exp
oracle数据库怎么迁移到另一个数据库
2024-05-07

golang数据库自动迁移怎么实现

在Go语言中,实现数据库自动迁移可以使用一些第三方库,如gorm、migrate等。下面以使用gorm库实现数据库自动迁移为例进行说明。1. 安装gorm库:使用go get命令安装gorm库。bashgo get -u gorm.io/g
2023-10-20

怎么迁移现有的数据库到Aurora数据库

迁移现有的数据库到Aurora数据库可以通过以下步骤完成:创建一个新的Aurora数据库实例:首先在控制台上创建一个新的Aurora数据库实例,选择合适的数据库引擎和配置。导出现有数据库数据:使用适当的工具(如mysqldump或pg_d
怎么迁移现有的数据库到Aurora数据库
2024-04-09

怎么使用dbeaver进行数据迁移

要使用DBeaver进行数据迁移,你可以按照以下步骤操作:打开DBeaver并连接到源数据库和目标数据库。在DBeaver的主界面上,选择“数据库”菜单,然后选择“数据传输”。在数据传输向导中,选择源数据库连接和目标数据库连接。选择要迁移的
怎么使用dbeaver进行数据迁移
2024-03-14

linux中fastdfs数据迁移怎么实现

在Linux中,可以使用以下方法实现FastDFS数据迁移:使用FastDFS提供的工具进行数据迁移:FastDFS提供了一个叫做fdfs_migrate_tool的工具,可以用于在不同的FastDFS集群之间进行数据迁移。该工具可以将源F
2023-10-24

编程热搜

目录