Oracle使用dump转储数据块

alter system dump datafile {File no} block {Block no};
alter system dump datafile 4 block 129;
alter system dump datafile {File no} block min {Block min} block max {Block max};
alter system dump datafile 4 block min 129 block max 133;

alter system dump datafile '{name}' block {Block no};
alter system dump datafile '{name}' block min {Block min} block max {Block max};

1、创建测试表

从上面的查询中可以看到三条数据都存储在4号文件的37771块上。
3、使用dump命令转储块信息到trace文件中,并找到相应的trace文件

4、查看trace文件中的内容
wKiom1ngNYfCh_0zAABwv61ESF0939.png
wKioL1ngMtGy8gXYAACJpOS68sw753.png
上面截取了一些信息:包含表的object_id <objn 90835>,表上的事务槽信息、表中的三行数据的详细信息等。
转储出来的trace文件包含大量的信息,如果能看懂并分析这样的trace文件,说明向大师又迈近了一步。
不同版本对数据库dump出来的trace文件,出处有所不同,可能是从磁盘也可能是从buffer cache中,有兴趣的同学可以自行测试。

参考:《Oracle Core Essential Internals for DBAs and Developers》

猜你喜欢

转载自www.linuxidc.com/Linux/2017-11/148747.htm