oracle 使用者跟蹤 需要的sql語句總結
今天同事反應前臺應用頁面的執行的速度很慢,想按照session跟蹤一下sql,看是否能有最佳化的空間,我連線上資料庫之後,發現應用有很多連線到資料庫中,不確定session是我們要跟蹤的使用者,仔細的想了一下,如何能快速的鎖定使用者,我的想法操作如下:
--檢視session中是mahanso的使用者(注意:要大寫)
select * from v$session
where username = 'MAHANSO'
--檢視
SELECT * FROM V$DB_OBJECT_CACHE
where wner = 'MAHANSO'
and type = 'TABLE'
--檢視oracle連線使用者執行的sql語句,但是是不能確定覺得session中sid、serial#,username
select /*+ PUSH_SUBQ */
command_type,
sql_text,
sharable_mem,
persistent_mem,
runtime_mem,
sorts,
version_count,
loaded_versions,
open_versions,
users_opening,
executions,
users_executing,
loads,
first_load_time,
invalidations,
parse_calls,
disk_reads,
buffer_gets,
rows_processed,
sysdate start_time,
sysdate finish_time,
'>' || address sql_address,
'N' status
from v$sqlarea
where address = (select sql_address from v$session where sid = 884)
--檢視“作業系統”程式 使用者 執行的sql語句,但是當我用ps -ef |grep ora檢視作業系統程式的時候,我暈倒,有N多連線連在資料庫上。
select distinct c.spid 程式號,
b.sid oracle程式號,
b.username 使用者名稱,
a.module 程式型別,
a.hash_value,
sql_text SQL語句
from v$sql a, v$session b, v$process c
where a.hash_value = b.sql_hash_value
and a.address = b.sql_address
and b.paddr = c.addr
and c.spid = (作業系統的程式號)
--檢視oracle中session執行sql語句的情況
select * from v$sql
/****************************************************************************************************************/
P.S 這裡要學習了一下:v$sql、v$sqlarea、v$sqltext區別
1、查一下這些檢視的定義你就能理解,它們的源都是一個。
SELECT view_definition FROM v$fixed_view_definition WHERE view_name='GV$SQL';
SELECT view_definition FROM v$fixed_view_definition WHERE view_name='GV$SQL_AREA';
2、實際上最模糊的是v$sql與v$sqlarea,區別與聯絡除biti說的還有:
a、v$sql_area相當於是按INST_ID, KGLNAOBJ, KGLHDPAR, KGLNAHSH, KGLNATIM, GLOBTS0,GLOBT19, KGLOBTS1, KGLOBT20,DECODE(KGLOBT33, 1, 'Y', 'N'),KGLHDCLT這些列的自v$sql的group by,也就是說v$sql的每一行表示的是每一個sql語句的一個versiion,而v$sqlarea存放的是相同語句不同version一個彙總。
b、 v$sql與v$sqlarea的源都是一個:X$KGLCURSOR
c、實際調優中建議使用v$sql,相對來說比v$sqlarea快,而且還不會產生share pool latch的爭用。
3、因v$sql及v$sqlarea存放著統計資訊在調優時使用居多,但其sql是不全的,如果想獲得完整的sql就要用v$sqltext了。
/****************************************************************************************************************/
--檢視在'MAHANSO'使用者下執行的所有的sql語句,按照時間降序排列
select * from v$sqlarea t where t.PARSING_SCHEMA_NAME in ('MAHANSO') order by t.LAST_ACTIVE_TIME desc
--我向前端應用工程師瞭解目前我們測試頁面的sql語句
--檢視目前“mahanso”使用者所有session中執行那些sql,找到我要跟蹤的sql語句,最後確定下來session的sid、serial#、username,進行跟蹤。
select * from v$session b,v$sql a
where a.address = b.sql_address
and username = 'MAHANSO'
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/12272958/viewspace-677307/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Oracle執行語句跟蹤 使用sql trace實現語句追蹤OracleSQL
- phalcon:跟蹤sql語句SQL
- 使用oracle的10046事件跟蹤SQL語句Oracle事件SQL
- sqlplus 跟蹤sql語句SQL
- mysql如何跟蹤執行的sql語句MySql
- 使用10046跟蹤sql語句SQL
- SQL效能的度量 - 語句級別的SQL跟蹤autotraceSQL
- oracle跟蹤事件(dump)總結Oracle事件
- SQL SERVER 跟蹤標記總結SQLServer
- 【MySQL】如何對SQL語句進行跟蹤(trace)?MySql
- 依據錯誤號來跟蹤sql語句SQL
- 跟蹤使用者的SQLSQL
- 關於oracle中session跟蹤的總結OracleSession
- [20150527]跟蹤單個sql語句.txtSQL
- SQL語句規範總結SQL
- MySQL基本sql語句總結MySql
- sql語句學習總結SQL
- SQL語句使用總結(一)SQL
- Oracle行轉列、列轉行的Sql語句總結OracleSQL
- MyCat不支援的SQL語句總結SQL
- Oracle 跟蹤全部使用者Oracle
- oracle 跟蹤其他使用者Oracle
- Oracle資料庫跟蹤SQLOracle資料庫SQL
- [20160704]從跟蹤檔案抽取sql語句.txtSQL
- [20130226]跟蹤特定IP的sql語句.txtSQL
- oracle的sql語句OracleSQL
- SQL單表查詢語句總結SQL
- 透過ORADEBUG運用10046事件跟蹤SQL語句事件SQL
- Oracle常用維護語句總結Oracle
- oracle sql語句OracleSQL
- 0624使用10035事件跟蹤無法執行的sql語句事件SQL
- Oracle SQL 跟蹤 --- dbms_system.set_sql_trace_in_sessionOracleSQLSession
- oracle sql跟蹤 event 10046 - 轉OracleSQL
- ORACLE開啟自動跟蹤SQL 功能。OracleSQL
- SQL 的跟蹤方法traceSQL
- SQL語句大全,你需要的SQL在這裡SQL
- Oracle經典sql語句總結@sql-plus重點函式串講與sql語句案例@中文排序詳講).docOracleSQL函式排序
- 如何收集Oracle程式中的SQL跟蹤資訊KUOracleSQL