程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> Oracle數據庫基礎 >> 識別占用資源較多的Oracle語句的方法

識別占用資源較多的Oracle語句的方法

編輯:Oracle數據庫基礎

識別占用資源較多的Oracle語句對於我們解決SQL語句執行效率問題大有幫助,下面就為您介紹識別占用資源較多的Oracle語句的方法,供您參考。

1.測試組和最終用戶反饋的與反應緩慢有關的問題。

2.利用V_$SQLAREA視圖提供了執行的細節。(執行、讀取磁盤和讀取緩沖區的次數)

數據列:

execUTIONS:執行次數

DISK_READS:讀盤次數

COMMAND_TYPE:命令類型(3:select,2:insert;6:update;7delete;47:pl/sql程序單元)

OPTIMIZER_MODE:優化方式

SQL_TEXT:Sql語句

SHARABLE_MEM:占用shared pool的內存多少

BUFFER_GETS:讀取緩沖區的次數

用途:

1、幫忙找出性能較差的SQL語句

2、幫忙找出最高頻率的SQL

3、幫忙分析是否需要索引或改善聯接

監控當前Oracle:family: ’Times New Roman’; mso-hansi-font-family: ’Times New Roman’">的session,如出現時鐘的標志,表示此進程中的sql運行時間較長。
 
4. Trace工具:

a)查看數據庫服務的初始參數:timed_statistics、user_dump_dest和max_dump_file_size

b)Step 1: alter session set sql_trace=true

c)Step 2: run sql;

d)Step 3: alter session set sql_trace=false

e)Step 4:使用 “TKPROF”轉換跟蹤文件

f)Parse,解析數量大通常表明需要增加數據庫服務器的共享池大小,

query或current提取數量大表明如果沒有索引,語句可能會運行得更有效,

disk提取數量表明索引有可能改進性能,

library cache中多於一次的錯過表明需要一個更大的共享池大小

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved