請問如何查詢ORACLE的歷史操做記錄!!!!!
------解決方案--------------------
有一個專門存儲操做的數據庫表。。
select t.SQL_TEXT, t.FIRST_LOAD_TIME
from v$sqlarea t
where t.FIRST_LOAD_TIME like '2010-06-30%'
order by t.FIRST_LOAD_TIME desc前端
===========sql
SELECT v$open_cursor.SID,v$sql.sql_text,v$open_cursor.CURSOR_TYPE,v$session.PROGRAM
FROM v$session, v$open_cursor,V$sql
WHERE v$open_cursor.saddr = v$session.saddr
and v$open_cursor.SID=v$session.SID
and v$open_cursor.SQL_ID=v$sql.SQL_ID
and v$session.OSUSER='adcc'
and v$open_cursor.CURSOR_TYPE='OPEN'
and v$session.PROGRAM='iisexpress.exe'
order by v$open_cursor.CURSOR_TYPE desc數據庫
==========express
用戶名大寫session
select t.SQL_TEXT, t.PARSING_SCHEMA_NAME, t.LAST_ACTIVE_TIME
from v$sqlarea t where t.PARSING_SCHEMA_NAME in ('WCQ') order by t.LAST_ACTIVE_TIME desc
oracle
===================學習
今天同事反應前臺應用頁面的執行的速度很慢,想按照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區別
一、查一下這些視圖的定義你就能理解,它們的源都是一個。
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';
二、實際上最模糊的是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的爭用。
三、因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'測試