成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Oracle SQL trace的正確使用以及需注意的問題

數據庫 Oracle
以下的文章主要是介紹如何正確使用Oracle SQL trace,以及在實際操作中都有哪些值得我們注意的問題,以下就是正文的主要內容的描述。

今天主要向大家介紹的是如何正確的使用Oracle Sql Trace與10046 event來對Oracle數據庫的性能進行相關的診斷,我們大家都知道level超過1的10046事件時通常被稱為extended sql trace,通常用于診斷確定的單個SQL、存儲過程或會話的性能問題,具有如下的幾個優點:

可以得到SQL執行時實際的執行計劃。

可以得到SQL執行時所花時間的具體分布,CPU消耗了多長時間,多塊讀消耗了多長時間等等。

可以得到SQL執行時的各種與性能相關的統計數據,邏輯讀、物理讀、fetch次數、parse次數等等。

不僅能夠用于性能測試,同時能夠用于診斷正在執行的SQL或存儲過程的性能。

有很多的工具用于格式化生成的trace文件,除了Oracle自帶的TKPROF、Metalink Note 224270.1 Trace Analyzer,以及第三方的免費工具如orasrp,《Troubleshooting Oracle Performance》作者開發的TVD$XTAT,甚至還有商業化的軟件Hotsos Profiler等。

不過前段時間在用10046事件診斷一個性能問題的時候,卻讓生成的結果誤導了。后來仔細檢查發現,在會話開啟Oracle sql trace的情況下,SQL語句會重新解析,導致開啟sql trace之后與開啟之前相比,執行計劃可能發生了變化,導致sql trace的結果不能真實地反映會話執行SQL的情況,在分析時容易發生偏差。

下面是一個測試:

測試的環境是Oracle 10.2.0.1 for Windows,不過前面提到的案例,是發生在Oracle 9i下的,所以9i和10g都有這個問題,而11g目前還沒有測試過,有興趣的朋友可以在11g上進行測試。

首先創建一個sql文件,內容為:

  1. select /*+ testsql */ sum(value) from t1 where flag=:v_flag;  

創建一個列上數據有傾斜的表

  1. SQL> create table t1 (value number ,flag number,pad varchar2(2000));  

表已創建。

  1. SQL> insert into t1 select rownum,mod(rownum,2000),lpad('x',1000,'x') from dba_objects;  

已創建49796行。

  1. SQL> commit;  

提交完成。

  1. SQL> insert into t1 select rownum,3000,lpad('x',1000,'x') from dba_objects where rownum<=10000;  

已創建10000行。

  1. SQL> commit;  

提交完成。

  1. SQL> create index t1_idx on t1(flag);  

索引已創建。

  1. SQL> exec dbms_stats.gather_table_stats(ownname=>user,tabname=>'T1',cascade=>true,method_opt=>'for all indexed columns');  

PL/SQL 過程已成功完成。

  1. SQL> select column_name,num_distinct,num_buckets from user_tab_columns where table_name='T1';   
  2. COLUMN_NAME NUM_DISTINCT NUM_BUCKETS   
  3. ------------------------------ ------------ -----------   
  4. VALUE   
  5. FLAG 2030 75   
  6. PAD   
  7. select /*+ testsql */ sum(value) from t1 where flag=:v_flag;  

創建一個列上數據有傾斜的表:

  1. SQL> create table t1 (value number ,flag number,pad varchar2(2000));  

表已創建。

  1. SQL> insert into t1 select rownum,mod(rownum,2000),lpad('x',1000,'x') from dba_objects;  

已創建49796行。

  1. SQL> commit;  

提交完成。

 

  1. SQL> insert into t1 select rownum,3000,lpad('x',1000,'x') from dba_objects where rownum<=10000; 

已創建10000行。

  1. SQL> commit;  

提交完成。上述的相關內容就是對使用Oracle SQL trace時需要注意的問題的描述,希望會給你帶來一些幫助在此方面。

【編輯推薦】

  1. 實現Oracle傳輸表空間的實際功能解析
  2. Oracle rownum用法的歸納
  3. Oracle存儲過程定時執行2種方法
  4. Oracle 10g中的hints調整機制詳解
  5. 提高Oracle SQL的執行效率的3個方案
責任編輯:佚名 來源: 博客園
相關推薦

2010-05-06 16:02:42

Oracle SQL

2015-04-16 16:42:11

私有云云部署

2010-09-01 09:03:25

DB2臨時表

2011-05-05 14:27:17

噴碼機耗材

2010-04-23 09:51:12

Oracle工具

2013-05-08 09:14:35

網絡維護網吧網管

2017-05-25 11:49:30

Android網絡請求OkHttp

2023-09-28 09:07:54

注解失效場景

2011-07-27 09:57:24

SQL TraceOracle

2013-10-21 14:39:40

數據

2009-06-11 16:42:51

家庭組網網絡設備安裝

2011-09-14 15:23:00

Android 2.2

2011-07-01 15:27:29

網站優化

2011-07-11 13:16:19

SQL TraceSQL Profile

2010-05-20 18:15:31

2010-07-19 16:55:51

Telnet命令

2013-04-07 11:31:05

云計算合同

2011-07-03 23:40:54

友情鏈接

2009-07-20 15:37:09

iBatis like注入漏洞

2010-04-07 14:59:02

校園服務器
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 神马久久香蕉 | 青青艹在线视频 | 欧美精品a∨在线观看不卡 国产精品久久国产精品 | 国产一区二区三区欧美 | 欧美不卡一区二区 | 欧美日韩免费在线 | 蜜桃精品视频在线 | 国产精品视频www | 免费同性女女aaa免费网站 | 国产成人精品免费 | 国产成人精品一区二区三区网站观看 | 久久欧美精品 | 99久久精品视频免费 | 久久精品国产99国产精品 | 在线精品一区二区 | 在线视频国产一区 | 黑人久久| 久久宗合色 | 久久久av | 欧美激情久久久 | 一级黄色片网址 | 国产精品污www一区二区三区 | 免费一级毛片 | 五月婷婷中文 | 国产精品久久久久久久久图文区 | 在线观看国产视频 | 男女羞羞在线观看 | 91精品国产乱码久久久久久久久 | 在线免费观看日本视频 | 男人天堂网址 | 天天操天天干天天曰 | 日韩一级免费看 | 精品国产91| 特黄毛片 | 久久99精品国产自在现线小黄鸭 | 国产在线观看一区二区 | 日韩一区中文字幕 | 欧美日韩亚 | 国产精品国产馆在线真实露脸 | 午夜私人影院在线观看 | 91xxx在线观看 |