查看SQL执行计划常用方法

gang165165

gang165165

2016-02-19 19:18

给自己一点时间接受自己,爱自己,趁着下午茶的时间来学习图老师推荐的查看SQL执行计划常用方法,过去的都会过去,迎接崭新的开始,释放更美好的自己。

  不论是做为开发DBA还是维护DBA,总是或多或少地遇到SQL执行效率或者说SQL调优问题,查看执行计划是必须的。一般我们可以用3种方法查看:

(本文来源于图老师网站,更多请访问https://m.tulaoshi.com/bianchengyuyan/)

  一、explain plan for

  举例就足以说明其用法  

   sys@ORCLexplainplanfor
  2selectsysdatefromdual;
  Explained.
  sys@ORCLselect*fromtable(dbms_xplan.display());
  PLAN_TABLE_OUTPUT
  ----------------------------------------------------------------------------------------------------
  --------------------------------------------------------------------
  |Id|Operation|Name|Rows|Bytes|Cost|
  --------------------------------------------------------------------
  |0|SELECTSTATEMENT|||||
  |1|TABLEACCESSFULL|DUAL||||
  --------------------------------------------------------------------
  Note:rulebasedoptimization
  9rowsselected.

  二、利用TKPROF工具

  TKPROF是一个用于分析oracle跟踪文件并且产生一个更加清晰合理的输出结果的可执行工具。如果一个系统的执行效率比较低,一个比较好的方法是跟踪用户的会话并且使用TKPROF工具的排序功能格式化输出,从而找出有问题的SQL语句。

  TKPROF命令后面的选项及输出文件各个列的含义在这里不做详细的介绍。 google一下就会有很多资料。

  下面简单描述一下TKPROF工具的使用步骤:

  1、在session级别设置sql_trace=true

   sys@ORCLaltersessionsetsql_trace=true;
  Sessionaltered.

  如果要在pl/sql中对session级别设置true,可以使用dbms_system这个包:

(本文来源于图老师网站,更多请访问https://m.tulaoshi.com/bianchengyuyan/)

  sys@ORCL exec dbms_system.set_sql_trace_in_session(sid,serial#,true);

  2、指定一下生成的trace文件的名字,便于查找:  

   sys@ORCLaltersessionsettracefile_identifier='yourname';

  3、执行SQL语句。

  4、利用TKPROF工具格式化输出的trace 文件:

 [oracle@q1test01~] $tkprof/oracle/admin/orcl/udump/orcl_ora_10266_yourname.trc/oracle/yourname.txtexplain=user/pwdaggregate=yessys=nowaits=yessort=fchela

  5、查看生成的文件再设置sql_trace=false: 

   sys@ORCLaltersessionsetsql_trace=false;

  三、set autotrace on

  此种方法最常用,关于如何设置sql*plus的autotrace这里也不做详细介绍,因为google上面资料确实太多了。有心的朋友可以去找找,保证有一大堆适合你的资料。

  举个例子,这种方法简单易懂: 

   ctoc@ORCLsetautotraceon
  ctoc@ORCLselectsysdatefromdual;
  SYSDATE
  ---------
  25-JUN-08
  ExecutionPlan
  ----------------------------------------------------------
  0SELECTSTATEMENTptimizer=CHOOSE
  10TABLEACCESS(FULL)OF'DUAL'
  Statistics
  ----------------------------------------------------------
  0recursivecalls
  0dbblockgets
  3consistentgets
  0physicalreads
  0redosize
  522bytessentviaSQL*Nettoclient
  655bytesreceivedviaSQL*Netfromclient
  2SQL*Netroundtripsto/fromclient
  0sorts(memory)
  0sorts(disk)
  1rowsprocessed

展开更多 50%)
分享

猜你喜欢

查看SQL执行计划常用方法

编程语言 网络编程
查看SQL执行计划常用方法

MYSQL explain 执行计划

编程语言 网络编程
MYSQL explain 执行计划

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

查看Oracle的执行计划一句话命令

编程语言 网络编程
查看Oracle的执行计划一句话命令

Oracle数据库执行计划的一些基本概念 (1)

编程语言 网络编程
Oracle数据库执行计划的一些基本概念 (1)

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

批量执行sql语句的方法

编程语言 网络编程
批量执行sql语句的方法

Oracle数据库执行计划的一些基本概念 (2)

编程语言 网络编程
Oracle数据库执行计划的一些基本概念 (2)

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

SQL Server 7.0到2005的安全漏洞会允许登录权限提高?

SQL Server 7.0到2005的安全漏洞会允许登录权限提高?

如何u盘安装win7系统教程

如何u盘安装win7系统教程
下拉加载更多内容 ↓