Oracle历史记录
请问如何查询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
===========
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
==========
用户名大写
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
===================
今天同事反应前台应用页面的执行的速度很慢,想按照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'
Oracle历史记录的更多相关文章
- 查看oracle的sql语句历史记录和锁表的情况
查看oracle的sql语句历史记录和锁表的情况 (2012-01-04 20:59:59) 转载▼ 标签: 杂谈 分类: database 查询sql的历史记录 select * from v$sq ...
- 利用rlwrap配置linux下oracle sqlplus 历史记录回调
.下载rlwrap wget http://utopia.knoware.nl/~hlub/uck/rlwrap/rlwrap-0.42.tar.gz .解压 tar -xvzf rlwrap-0.4 ...
- oracle sqlplus不支持上下键查看历史记录问题
我们需要安装rlwrap软件 系统采样: [root@rac-2 src]# su - oracle Last login: Fri Mar 18 23:36:25 CST 2022 on pts/0 ...
- 查看oracle 用户执行的sql语句历史记录
select * from v$sqlarea t order by t.LAST_ACTIVE_TIME desc
- 查看oracle用户执行的sql语句历史记录
select PARSING_SCHEMA_NAME,COUNT(DISTINCT T.SQL_TEXT) from v$sqlarea t WHERE T.LAST_ACTIVE_TIME > ...
- oracle undo回滚段详解
1.Undo是干嘛用的? 在介绍undo之前先说一下另外一个东西 transaction ,翻译成交易或事务.我们在进行一个事务的过程中需要申请许多资源,一个复杂的事务也需要很多步来完成.那么一个 ...
- Oracle库Delete删除千万以上普通堆表数据的方法
需求:Oracle数据库delete删除普通堆表千万条历史记录. 直接删除的影响: 1.可能由于undo表空间不足从而导致最终删除失败的问题: 2.可能导致undo表空间过度使用,影响到其他用户正常操 ...
- Oracle体系结构详解
对于一门技术的学习,尤其是像Oracle database这种知识体系极其庞杂的技术来讲,从宏观上了解其体系结构是至关重要的.同时,个人认为,未必是专业DBA人员才需要了解其体系结构(固然对于数据库专 ...
- oracle 归档日志
归档日志(Archive Log)是非活动的重做日志备份.通过使用归档日志,可以保留所有重做历史记录,当数据库处于ARCHIVELOG模式并进行日志切换式,后台进程ARCH会将重做日志的内容保存到归档 ...
随机推荐
- /etc/security/limits.conf 设置
jrhdpt01:/root# cat /etc/security/limits.conf * soft nofile 65535 * hard nofile 65535 * soft npro ...
- Valera and Tubes
C. Valera and Tubes time limit per test 1 second memory limit per test 256 megabytes input standard ...
- centos6安装bt工具transmission
centos6 install transmission 1. 安装所需的组件: yum -y install gcc gcc-c++ m4 make automake libtool gettex ...
- SRM 624 Building Heights DivI 解读
几乎相同的一标题.欲了解更多请参阅:http://community.topcoder.com/stat?c=problem_statement&pm=13211&rd=15857 思 ...
- 浅析Delphi Container库(有开源的DCLX)
与Java和C++相比,Delphi对容器的支持实在少得可怜.Java有强大的集合框架,C++更有STL,Delphi有什么呢,不就是TList几个小巧的列表类,而TCollection系列的类更多只 ...
- 七内部排序算法汇总(插入排序、Shell排序、冒泡排序、请选择类别、、高速分拣合并排序、堆排序)
写在前面: 排序是计算机程序设计中的一种重要操作,它的功能是将一个数据元素的随意序列,又一次排列成一个按keyword有序的序列.因此排序掌握各种排序算法很重要. 对以下介绍的各个排序,我们假定全部排 ...
- [转]PHP 5.2~5.6 对照以及功能具体解释
[分享]PHP 5.2~5.6 对照以及功能具体解释 作者:流水理鱼wwek 来源:http://www.iamle.com/archives/1530.html 截至眼下(2014.2), PHP ...
- Shell编程中Shift的用法(转)
位置参数可以用shift命令左移.比如shift 3表示原来的$4现在变成$1,原来的$5现在变成$2等等,原来的$1.$2.$3丢弃,$0不移动.不带参数的shift命令相当于shift 1. 非常 ...
- PYQT4 + Python2.6 + eric4-4.2.2a的安装全过程
PYQT4 + Python2.6 + eric4-4.2.2a的安装全过程 - beike - ITeye技术网站 PYQT4 + Python2.6 + eric4-4.2.2a的安装全过程 博客 ...
- AFNetworking2.0后 进行Post请求
本文以新浪微博的Oauth认证为样例进行Post请求的演示 以下直接上代码: #import "ViewController.h" #import "AFNetworki ...