標籤: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