成人免费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'); 

Oracle SQL trace時需要注意: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. VALUE   
  4. FLAG 2030 75   
  5. PAD   
  6. 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數據庫中如何用GROUPING SETS進行分組自定義
  2. Oracle數據庫與FoxPro數據如何轉換
  3. Oracle數據庫中的(+)連接如何操作?
  4. Oracle存儲過程中如何準確的實現分頁
  5. Oracle 10g的即時客戶端與PHP的安裝
責任編輯:佚名 來源: 互聯網
相關推薦

2011-08-22 15:47:27

Oracle臨時表存儲過程

2010-03-29 11:06:22

Oracle Spat

2010-04-30 17:50:25

2010-05-06 10:09:44

Oracle in

2010-06-17 10:22:47

PHP

2010-03-18 13:49:40

ATM交換機

2010-06-28 15:13:52

SNMP協議

2010-04-30 11:10:32

Oracle Sql

2010-04-13 14:25:24

Oracle問題解決

2010-03-29 11:17:33

Oracle Spat

2010-04-29 16:53:18

Oracle多表關聯

2009-11-03 11:03:00

CDN接入技術

2024-02-27 16:27:42

物聯網IOT智能連接

2010-03-30 14:32:38

Oracle Date

2011-05-17 10:49:55

OracleSQL Server

2010-04-13 18:03:33

Oracle服務

2010-04-06 15:23:42

Oracle sql

2010-04-08 18:33:46

Oracle VARR

2021-08-28 10:06:29

VueJavascript應用

2010-01-06 15:21:00

軟交換技術
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美一级在线 | 欧美日韩视频在线 | 亚洲最大av | 91免费福利视频 | 国产日韩精品视频 | 亚洲精品成人网 | 黄色中文字幕 | 伊大人久久 | 日本久久综合 | 日韩一二三 | 国产精品日韩欧美一区二区三区 | 日韩在线精品视频 | 久久久做 | 国产欧美一区二区三区久久人妖 | 丁香久久| 免费在线观看成人 | 免费看黄色片 | 午夜精品一区二区三区在线播放 | 碰碰视频 | 国内久久精品 | 日韩欧美1区2区 | 人妖一区 | 女同久久另类99精品国产 | 99伊人网| 亚洲欧美国产精品一区二区 | 日韩三级免费网站 | 91久久国产综合久久 | www在线视频 | 亚洲第一在线 | av播播 | 免费日韩av | 亚洲精品一区中文字幕乱码 | 欧美成人在线免费 | 国产精品成av人在线视午夜片 | 一级黄色生活视频 | 成人在线观看免费爱爱 | 国产精品色 | 天天噜天天干 | 日韩av中文 | 中文字幕在线视频免费观看 | 一区二区中文字幕 |