Oracle 資料庫最佳化-分析現有的sql

來源:互聯網
上載者:User

標籤:des   io   ar   使用   sp   strong   on   資料   bs   

在做資料庫sql最佳化時,首先要對現有的資料庫sql進行最佳化,主要包括以下幾種:

1、資料庫正在執行的SQL是?

2、已經執行過得SQL是?

3、最耗時的的前幾條SQL是?

4、最耗IO的SQL是?

5、某條SQL執行的計劃是?某條SQL上的最佳化策略是否起作用?

以下,將對上面的幾種情況分別陳述。

一、查詢正在執行的sql。

select a.username, a.sid,b.SQL_TEXT, b.SQL_FULLTEXT
from v$session a, v$sqlarea b
where a.sql_address = b.address AND B.PARSING_SCHEMA_NAME=‘GTSPM‘ #PARSING_SCHEMA_NAME  某個使用者名稱

二、查詢已經執行過得sql

select b.SQL_TEXT,b.FIRST_LOAD_TIME,b.SQL_FULLTEXT
from v$sqlarea b WHERE B.PARSING_SCHEMA_NAME=‘GTSPM‘ order by first_load_time desc

三、查詢效能最差的前N條SQL

SELECT * FROM (select PARSING_USER_ID,EXECUTIONS,SORTS,
COMMAND_TYPE,DISK_READS,sql_text FROM v$sqlarea WHERE PARSING_SCHEMA_NAME=‘GTSPM‘
order BY disk_reads DESC )where ROWNUM<10 ;

四、最耗IO的SQL

SELECT se.sid,se.serial#,pr.SPID,se.username,se.status,
se.terminal,se.program,se.MODULE,se.sql_address,st.event,st.
p1text,si.physical_reads,
si.block_changes FROM v$session se,v$session_wait st,
v$sess_io si,v$process pr WHERE st.sid=se.sid AND st.
sid=si.sid AND se.PADDR=pr.ADDR AND se.sid>6 AND st.
wait_time=0 AND st.event NOT LIKE ‘%SQL%‘ ORDER BY physical_reads DESC

五、查詢sql的執行計畫。

  查看索引是否生效、是否進行全表掃描、索引使用是否合理。

 

Oracle 資料庫最佳化-分析現有的sql

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.