查詢Oracle中正在執(zhí)行和執(zhí)行過的SQL語句
查詢Oracle正在執(zhí)行的sql語句及執(zhí)行該語句的用戶
SELECT b.sid oracleID, b.username 登錄Oracle用戶名, b.serial#, spid 操作系統(tǒng)ID, paddr, sql_text 正在執(zhí)行的SQL, b.machine 計算機名 FROM v$process a, v$session b, v$sqlarea c WHERE a.addr = b.paddr AND b.sql_hash_value = c.hash_value
其它網(wǎng)友給出的正在執(zhí)行的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 ---執(zhí)行過的 select b.SQL_TEXT,b.FIRST_LOAD_TIME,b.SQL_FULLTEXT from v$sqlarea b where b.FIRST_LOAD_TIME between '2016-10-1/09:24:47' and '2016-10-1/09:24:47' order by b.FIRST_LOAD_TIME
(此方法好處可以查看某一時間段執(zhí)行過的sql,并且 SQL_FULLTEXT 包含了完整的 sql 語句)
其他
select OSUSER,PROGRAM,USERNAME,SCHEMANAME,B.Cpu_Time,STATUS,B.SQL_TEXT from V$SESSION A LEFT JOIN V$SQL B ON A.SQL_ADDRESS=B.ADDRESS AND A.SQL_HASH_VALUE=B.HASH_VALUE order by b.cpu_time desc select address, sql_text, piece from v$session, v$sqltext where address = sql_address -- and machine = < you machine name > order by address, piece
查看正在執(zhí)行sql的發(fā)起者的發(fā)放程序
SELECT OSUSER 電腦登錄身份, PROGRAM 發(fā)起請求的程序, USERNAME 登錄系統(tǒng)的用戶名, SCHEMANAME, B.Cpu_Time 花費cpu的時間, STATUS, B.SQL_TEXT 執(zhí)行的sql FROM V$SESSION A LEFT JOIN V$SQL B ON A.SQL_ADDRESS = B.ADDRESS AND A.SQL_HASH_VALUE = B.HASH_VALUE ORDER BY b.cpu_time DESC
查出oracle當前的被鎖對象
SELECT l.session_id sid, s.serial#, l.locked_mode 鎖模式, l.oracle_username 登錄用戶, l.os_user_name 登錄機器用戶名, s.machine 機器名, s.terminal 終端用戶名, o.object_name 被鎖對象名, s.logon_time 登錄數(shù)據(jù)庫時間 FROM v$locked_object l, all_objects o, v$session s WHERE l.object_id = o.object_id AND l.session_id = s.sid ORDER BY sid, s.serial#;
kill掉當前的鎖對象可以為
alter system kill session 'sid, s.serial#‘;
查找前十條性能差的sql.
SELECT * FROM (select PARSING_USER_ID,EXECUTIONS,SORTS, COMMAND_TYPE,DISK_READS,sql_text FROM v$sqlarea order BY disk_reads DESC )where ROWNUM<10 ;
查看占io較大的正在運行的session
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
以上就是腳本之家小編整理的關于查詢Oracle中正在執(zhí)行和執(zhí)行過的SQL語句的相關內(nèi)容,如果你有更好的方法,請評論留言,謝謝
相關文章
常見數(shù)據(jù)庫系統(tǒng)比較 Oracle數(shù)據(jù)庫
常見數(shù)據(jù)庫系統(tǒng)比較 Oracle數(shù)據(jù)庫...2007-03-03Oracle 12CR2查詢轉(zhuǎn)換教程之表擴展詳解
Oracle 12cR2版本已經(jīng)發(fā)布有一段時間,下面這篇文章主要給大家介紹了關于Oracle 12CR2查詢轉(zhuǎn)換教程之表擴展的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考借鑒,下面隨著小編來一起學習學習吧2018-11-11Linux 自動備份oracle數(shù)據(jù)庫詳解
這篇文章主要介紹了Linux 自動備份oracle數(shù)據(jù)庫詳解方法的相關資料,數(shù)據(jù)庫的備份的重要性,不言而喻,希望能幫到大家,需要的朋友可以參考下2016-10-10Oracle 12c 新特性之多線程數(shù)據(jù)庫操作
這篇文章主要介紹了Oracle 12c 新特性之多線程數(shù)據(jù)庫操作,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-08-08詳解Oracle如何將txt文件中的數(shù)據(jù)導入數(shù)據(jù)庫
這篇文章主要介紹了Oracle如何將txt文件中的數(shù)據(jù)導入數(shù)據(jù)庫,文中通過代碼示例和圖文結合的方式給大家講解的非常詳細,對大家的學習或工作有一定的幫助,需要的朋友可以參考下2024-03-03oracle中使用group by優(yōu)化distinct
這篇文章主要介紹了oracle中使用group by優(yōu)化distinct的相關資料,需要的朋友可以參考下2015-11-11