自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

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

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

今天主要向大家介紹的是如何正確的使用Oracle Sql Trace與10046 event來對(duì)Oracle數(shù)據(jù)庫的性能進(jìn)行相關(guān)的診斷,我們大家都知道level超過1的10046事件時(shí)通常被稱為extended sql trace,通常用于診斷確定的單個(gè)SQL、存儲(chǔ)過程或會(huì)話的性能問題,具有如下的幾個(gè)優(yōu)點(diǎn):

可以得到SQL執(zhí)行時(shí)實(shí)際的執(zhí)行計(jì)劃。

可以得到SQL執(zhí)行時(shí)所花時(shí)間的具體分布,CPU消耗了多長(zhǎng)時(shí)間,多塊讀消耗了多長(zhǎng)時(shí)間等等。

可以得到SQL執(zhí)行時(shí)的各種與性能相關(guān)的統(tǒng)計(jì)數(shù)據(jù),邏輯讀、物理讀、fetch次數(shù)、parse次數(shù)等等。

不僅能夠用于性能測(cè)試,同時(shí)能夠用于診斷正在執(zhí)行的SQL或存儲(chǔ)過程的性能。

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

不過前段時(shí)間在用10046事件診斷一個(gè)性能問題的時(shí)候,卻讓生成的結(jié)果誤導(dǎo)了。后來仔細(xì)檢查發(fā)現(xiàn),在會(huì)話開啟Oracle sql trace的情況下,SQL語句會(huì)重新解析,導(dǎo)致開啟sql trace之后與開啟之前相比,執(zhí)行計(jì)劃可能發(fā)生了變化,導(dǎo)致sql trace的結(jié)果不能真實(shí)地反映會(huì)話執(zhí)行SQL的情況,在分析時(shí)容易發(fā)生偏差。

下面是一個(gè)測(cè)試:

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

首先創(chuàng)建一個(gè)sql文件,內(nèi)容為:

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

創(chuàng)建一個(gè)列上數(shù)據(jù)有傾斜的表

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

表已創(chuàng)建。

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

已創(chuàng)建49796行。

  1. SQL> commit;  

提交完成。

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

已創(chuàng)建10000行。

  1. SQL> commit;  

提交完成。

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

索引已創(chuàng)建。

  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;  

創(chuàng)建一個(gè)列上數(shù)據(jù)有傾斜的表:

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

表已創(chuàng)建。

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

已創(chuàng)建49796行。

  1. SQL> commit;  

提交完成。

 

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

已創(chuàng)建10000行。

  1. SQL> commit;  

提交完成。上述的相關(guān)內(nèi)容就是對(duì)使用Oracle SQL trace時(shí)需要注意的問題的描述,希望會(huì)給你帶來一些幫助在此方面。

【編輯推薦】

  1. 實(shí)現(xiàn)Oracle傳輸表空間的實(shí)際功能解析
  2. Oracle rownum用法的歸納
  3. Oracle存儲(chǔ)過程定時(shí)執(zhí)行2種方法
  4. Oracle 10g中的hints調(diào)整機(jī)制詳解
  5. 提高Oracle SQL的執(zhí)行效率的3個(gè)方案
責(zé)任編輯:佚名 來源: 博客園
相關(guān)推薦

2010-05-06 16:02:42

Oracle SQL

2010-09-01 09:03:25

DB2臨時(shí)表

2015-04-16 16:42:11

私有云云部署

2011-05-05 14:27:17

噴碼機(jī)耗材

2010-04-23 09:51:12

Oracle工具

2013-05-08 09:14:35

網(wǎng)絡(luò)維護(hù)網(wǎng)吧網(wǎng)管

2017-05-25 11:49:30

Android網(wǎng)絡(luò)請(qǐng)求OkHttp

2011-07-27 09:57:24

SQL TraceOracle

2023-09-28 09:07:54

注解失效場(chǎng)景

2009-06-11 16:42:51

家庭組網(wǎng)網(wǎng)絡(luò)設(shè)備安裝

2013-10-21 14:39:40

數(shù)據(jù)

2011-09-14 15:23:00

Android 2.2

2011-07-11 13:16:19

SQL TraceSQL Profile

2011-07-01 15:27:29

網(wǎng)站優(yōu)化

2010-07-19 16:55:51

Telnet命令

2013-04-15 09:48:40

AndroidAVD錯(cuò)誤處理方法

2010-05-20 18:15:31

2011-07-03 23:40:54

友情鏈接

2013-04-07 11:31:05

云計(jì)算合同

2010-07-26 10:59:59

SQL Server游
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)