oracle 查询最近执行过的 SQL语句

本文介绍Oracle数据库中查询最近执行过的SQL语句的方法,包括按不同类型SQL语句查询、查看正在执行的SQL及其详细信息,以及查找性能差的SQL等实用技巧。

oracle 查询最近执行过的 SQL语句

select sql_text,last_load_time from v$sql order by last_load_time desc;

SELECT   sql_text, last_load_time FROM v$sql WHERE last_load_time IS NOT NULL and sql_text like 'select%' ORDER BY last_load_time DESC;

SELECT   sql_text, last_load_time FROM v$sql WHERE last_load_time IS NOT NULL and sql_text like 'update%' ORDER BY last_load_time DESC;

SELECT   sql_text, last_load_time FROM v$sql WHERE last_load_time IS NOT NULL and last_load_time like' 14-06-09%' ORDER BY last_load_time DESC;



---正在执行的

select a.username, a.sid,b.SQL_TEXT, b.SQL_FULLTEXT
  from v$session a, v$sqlarea 
where a.sql_address b.address 
---执行过的
select b.SQL_TEXT,b.FIRST_LOAD_TIME,b.SQL_FULLTEXT
  from v$sqlarea b
where b.FIRST_LOAD_TIME between '2009-10-15/09:24:47' and
       '2009-10-15/09:24:47' order by b.FIRST_LOAD_TIME 
(此方法好处可以查看某一时间段执行过的sql,并且 SQL_FULLTEXT 包含了完整的 sql 语句)

其他
select OSUSER,PROGRAM,USERNAME,SCHEMANAME,B.Cpu_Time,STATUS,B.SQL_TEXT 
from V$SESSION LEFT JOIN V$SQL 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 

查找前十条性能差的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 数据库中,查看最近一段时间执行SQL 语句可以通过以下几种常见方法: ### 使用 DBA_HIST_SQLSTAT 和 DBA_HIST_SNAPSHOT 视图 可以结合 `DBA_HIST_SQLSTAT` 和 `DBA_HIST_SNAPSHOT` 视图来查询在特定时间范围内的 SQL 语句执行情况。以下是一个示例 SQL,用于查询最近 7 天内执行SQL 语句及其执行次数: ```sql SELECT ss.sql_id, ss.sql_text, SUM(ss.executions_delta) AS total_executions FROM DBA_HIST_SQLSTAT ss JOIN DBA_HIST_SNAPSHOT sn ON ss.snap_id = sn.snap_id WHERE sn.begin_interval_time BETWEEN SYSDATE - 7 AND SYSDATE GROUP BY ss.sql_id, ss.sql_text ORDER BY total_executions DESC; ``` 此查询将按照执行次数降序排序,显示出执行较为频繁的 SQL 语句。这里 `DBA_HIST_SQLSTAT` 存储了 SQL 语句的统计信息,`DBA_HIST_SNAPSHOT` 存储了数据库的快照信息,通过 `snap_id` 关联两个视图,利用 `begin_interval_time` 来筛选最近 7 天的数据 [^1]。 ### 使用 V$SQL 视图 `V$SQL` 视图存储了当前共享池中缓存的 SQL 语句信息。可以通过以下 SQL 查询最近执行SQL 语句: ```sql SELECT sql_id, sql_text FROM V$SQL WHERE last_active_time >= SYSDATE - INTERVAL '1' DAY ORDER BY last_active_time DESC; ``` 这个查询将显示最近一天内执行过的 SQL 语句,并按照最后执行时间降序排列。 ### 使用 AWR(自动工作负载资料库)报告 AWR 会定期收集数据库的性能统计信息,包括 SQL 语句执行情况。可以通过生成 AWR 报告来查看最近一段时间内执行SQL 语句及其性能指标。可以使用以下命令生成 AWR 报告: ```sql @?/rdbms/admin/awrrpt.sql ``` 执行该命令后,按照提示输入相关信息,如报告的时间范围等,即可生成 AWR 报告,从中可以找到执行SQL 语句及其详细的性能统计。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值