定位表中的行数据存放于哪一个具体的datafile上
来源:互联网 发布:打数字软件 编辑:程序博客网 时间:2024/06/07 12:02
副标题:用一个PL/SQL查出表中的行数据存放在哪个具体的datafile中
经常有遇到做DBA的朋友问,该如何知道自己插入的某一行数据,是存在了数据库中的哪一个数据文件(datafile)上了,回答是肯定可以的。在此,就将该方法写出来供更多的朋友使用。
1、正常查询步骤
1.1、先查到表上行数据的ROWID
select rowid from tivoli.test_db_avg1 where rownum =1
输出值:
AAAQ0mAAEAAAAhLAAA
1、2、根据ROWID定位到file id
select dbms_rowid.rowid_relative_fno(row_id=>'AAAQ0mAAEAAAAhLAAA')from dual
输出值:
4
1.3、根据file id定位到具体的文件路径和名称
select file_name from dba_data_fileswhere file_id=4
输出值:
/dba/oracle/oradata/single/users01.dbf
2、以上三个步骤,简化成一个PL/SQL块来实现
set serveroutput on
DECLARE
file_number INTEGER;
rowid_val ROWID;
file_name_val varchar2(100);
BEGIN
SELECT ROWID INTO rowid_val
FROM tivoli.test_db_avg1 where rownum =1;
file_number:=
dbms_rowid.rowid_relative_fno(rowid_val);
select file_name into file_name_val from dba_data_files where file_id = file_number;
dbms_output.put_line(file_name_val);
end;
/
输出结果:
/dba/oracle/oradata/single/users01.dbf
3、验证得出的结果是否正确
3.1 将datafile 4(/dba/oracle/oradata/single/users01.dbf)脱机
alter databasedatafile 4 offline;
3.2 再来查询tivoli.test_db_avg1表是否能正常查询
SQL> SELECT ROWID FROM tivoli.test_db_avg1 where rownum =1;
SELECT ROWID FROM tivoli.test_db_avg1 where rownum =1
*
ERROR at line 1:
ORA-00376: file 4 cannot be read at this time
ORA-01110: data file 4: '/dba/oracle/oradata/single/users01.dbf'
已不能正常查询,说明文件定位准确。
3.3 恢复datafile 4到联机状态
SQL> alter database recover datafile 4;
Database altered.
SQL> alter database datafile 4 online;
Database altered.
SQL> SELECT ROWID FROM tivoli.test_db_avg1 where rownum =1;
ROWID
------------------
AAAQ0mAAEAAAAhLAAA
又可以正常查询到tivoli.test_db_avg1表的数据,说明按照此文的方法,完全正确的找到了具体行数据存放在哪个具体的文件上了。
本文作者:黎俊杰(网名:踩点),从事”系统架构、操作系统、存储设备、数据库、中间件、应用程序“六个层面系统性的性能优化工作
欢迎加入 系统性能优化专业群,共同探讨性能优化技术。群号:258187244- 定位表中的行数据存放于哪一个具体的datafile上
- linux--如何查看文件内容具体的某一行数据
- 点击tableview上的btn 获得它所属于的cell并获得数据源的行数
- 将JavaBean对象的全部属性(包括父类属性)存放于map中的方法
- OPENGL在VC中的配置及出现“无法定位程序输入点_glutInitWithExit于动态链接库glut32.dll上”的解决方案
- 与datafile相关的表和视图
- 与datafile相关的表和视图
- 无法定位序数4540于动态链接库LIBEAY32.dll上(以及其它无法定位序数的解决方案)
- 无法定位程序输入点ldrlockloaderlock于动态链接库ntdll.dll上的解决办法
- 关于“无法定位程序输入点getaddrinfo于动态链接库WS32_32.dll上”的问题
- 关于无法定位程序输入点_glutInitWithExit于动态链接库glut32.dll上的解决方法
- 解决“无法定位程序输入点于动态链接库XX.DLL上”的方法
- 无法定位程序输入点于动态链接库上的解决方法
- 关于“无法定位程序输入点getaddrinfo于动态链接库WS32_32.dll上”的问题
- 无法定位程序输入点_glutInitWithExit于动态链接库glut32.dll上的解决方法
- 无法定位程序输入点于动态链接库上的原因
- MFC 鼠标定位于控件上动态弹出通知的实现方法
- 对于<<无法定位序数681于动态链接库 iertutil.dll上>>一文的后续
- Android SQLite 事务处理 Operation SQLite
- 直面 位操作
- 读取Java文件到byte数组的三种方式
- win7下 背景色更改为护眼颜色
- Kendo UI 学习
- 定位表中的行数据存放于哪一个具体的datafile上
- 查找字符串中最长重复字符的子串
- [C++]LeetCode: 104 Jump Game II (局部最优和全局最优法)
- java基础巩固系列(九):持有对象之间的使用与关系(Iterable、Collection、List、Queue、Set、Map、Stack)
- U3d动态加载声音
- java构造器
- Redis研究(八)—有序集合类型 1
- WV.9-动态链表-插入一个数到有序链表中并按原序排列
- tomcat性能调优