ITPub博客

首页 > 数据库 > Oracle > 读懂trace file (tkprof格式化) 3

读懂trace file (tkprof格式化) 3

原创 Oracle 作者:tolywang 时间:2014-03-19 13:21:23 0 删除 编辑

任何一个SQL都应该包含以下三个步骤:

a. 分析 (parse) : SQL的分析阶段
b. 执行 (execute) : SQL的执行阶段
c. 数据提取 (fetch) : 数据的提取阶段

分析阶段 -  比较容易理解,解析(软硬解析),比较并输出最好的一个执行计划
执行阶段 -  对于update, insert, delete 这些DML操作,所有的工作都在execute阶段完成了,没有fetch阶段。  select稍微复杂一些,大多数的select语句在execute阶段不做任何事情, 我们做的所有的工作就是打开游标,游标是一个指向shared pool内存区域的一个指针,正常来说,select 在这里不做任何事情(仅仅标识出查询出的行),它只是准备去做,但还未开始。

However, there are exceptions to everything - turn on trace and do a select * from scott.emp FOR UPDATE. That is a select, but it is also an update. You would see work done during the execute as well as the fetch phase. The work done during the execute was that of going out and touching every row and locking it. The work done during the fetch phase was that of going out and retrieving the data back to the client.

数据提取 -  这是我们能看到的select的几乎所有的工作(DML语句不需要),对于insert、update、delete操作,返回记录则是在execute这步。

备注:以上部分翻译自asktom,如需详细解释,请在asktom查询.

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/35489/viewspace-1124819/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论
Oracle , MySQL, SAP IQ, SAP HANA, PostgreSQL, Tableau 技术讨论,希望在这里一起分享知识,讨论技术,畅谈人生 。

注册时间:2007-12-10

  • 博文量
    5595
  • 访问量
    13467369