温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Oracle使用dump转储数据块

发布时间:2020-07-08 11:43:15 来源:网络 阅读:1481 作者:hbxztc 栏目:关系型数据库

在对Oracle做一些比较内核的研究时,会用需要用到dump命令把数据库中的信息转储到trace文件中。本文简单介绍使用dump命令把数据块中的信息转储到trace文件中。

实验环境:rhel7.2+11.2.0.4

语法:

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、创建测试表

zx@ORA11G>drop table t;

Table dropped.

zx@ORA11G>create table t as select * from dual;

Table created.

zx@ORA11G>select * from t;

D
-
X
X
X

3 rows selected.

2、查询数据表所在的数据块号

zx@ORA11G>select dbms_rowid.ROWID_RELATIVE_FNO(rowid),dbms_rowid.ROWID_BLOCK_NUMBER(rowid) from t;

DBMS_ROWID.ROWID_RELATIVE_FNO(ROWID) DBMS_ROWID.ROWID_BLOCK_NUMBER(ROWID)
------------------------------------ ------------------------------------
				   4				    37771
				   4				    37771
				   4				    37771

3 rows selected.

从上面的查询中可以看到三条数据都存储在4号文件的37771块上。

3、使用dump命令转储块信息到trace文件中,并找到相应的trace文件

zx@ORA11G>alter system dump datafile 4 block 37771;

System altered.

zx@ORA11G>select value from v$diag_info where name='Default Trace File';

VALUE
-------------------------------------------------------------------------
/u01/app/oracle/diag/rdbms/ora11g/ora11g/trace/ora11g_ora_5332.trc

4、查看trace文件中的内容

Oracle使用dump转储数据块

Oracle使用dump转储数据块

上面截取了一些信息:包含表的object_id <objn 90835>,表上的事务槽信息、表中的三行数据的详细信息等。

转储出来的trace文件包含大量的信息,如果能看懂并分析这样的trace文件,说明向大师又迈近了一步。

不同版本对数据库dump出来的trace文件,出处有所不同,可能是从磁盘也可能是从buffer cache中,有兴趣的同学可以自行测试。


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

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI