绑定完请刷新页面
取消
刷新

分享好友

×
取消 复制
10046中的p1,p2,p3参数与实际块编号不符
2020-06-27 04:02:28
我用alter session set events '10046 trace name context forever,level 12' 跟踪一个查询:select * from emp_reg where empno=100表emp_reg在empno列有索引. 跟踪显示有如下三个I/O: WAIT #1: nam='db file sequential read' ela= 5725 p1=16 p2=1314 p3=1 WAIT #1: nam='db file sequential read' ela= 211 p1=16 p2=1315 p3=1 WAIT #1: nam='db file sequential read' ela= 199 p1=16 p2=1311 p3=1 p1,p2,p3分别为文件、块与读块个数。现在p1=16是对的,但p2=1314 1315 1311跟本和表所在的块不符。 使用show_space显示的表emp_reg的所在块: SQL> exec show_space('EMP_REG'); Free Blocks.............................0 Total Blocks............................768 Total Bytes.............................3145728 Unused Blocks...........................176 Unused Bytes............................720896 Last Used Ext FileId....................16 Last Used Ext BlockId...................1809 Last Used Block.........................80 这上empno列上的索引的所在块 SQL> exec show_space('PK_EMP_REG',user,'INDEX'); Free Blocks.............................0 Total Blocks............................224 Total Bytes.............................917504 Unused Blocks...........................10 Unused Bytes............................40960 Last Used Ext FileId....................16 Last Used Ext BlockId...................1521 Last Used Block.........................6 这是为什么啊?
分享好友

分享这个小栈给你的朋友们,一起进步吧。

调试数据库 ---- 源码研究方法论
创建时间:2020-06-16 17:28:11
能让你坚持下去的源码学习方法 ---- 调试数据库。Oracle的各种DUMP、Trace和Event,增加了研究这个数据库的“乐趣”,使用Oracle成为一个可研究的数据库。开源数据库当然也可以通过钻研源码的方式去研究,但这样的学习周期太长。本课程教你用调试技术不断为MySQL/PostgreSQL扩展功能,在学习源码的同时,不断开发自己的、类似Oracle DUMP、Trace、Event的小工具,这就是我所说的“正向反馈”。用正向反馈,激励自己坚持下去,终成功。
展开
订阅须知

• 所有用户可根据关注领域订阅专区或所有专区

• 付费订阅:虚拟交易,一经交易不退款;若特殊情况,可3日内客服咨询

• 专区发布评论属默认订阅所评论专区(除付费小栈外)

栈主、嘉宾

查看更多
  • vage
    栈主

小栈成员

查看更多
  • 叶子,你好
  • 小雨滴
  • 潘佳伟
  • 东风快递
戳我,来吐槽~