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'
转载于:https://www.cnblogs.com/wangcq/p/3614552.html
Oracle历史记录相关推荐
- stm32cubeide 多通道adc_STM32L0开发——ADC多通道采集,IDE和IAR开发注意事项
keil开发L0系列是免费的,官方提供许可的.因此建议Keil开发, L011F3由于flash只有8K,因此不建议HAL库,建议使用cubemx+LL(或snippets库). 0.起初,可以参考官 ...
- 配置linux下oracle sqlplus/rman等历史记录回调功能
配置linux下oracle sqlplus/rman等历史记录回调功能 ############################################################ # ...
- oracle命令历史记录,oracle命令历史记录工具(rlwrap)
下载地址:https://github.com/hanslub42/rlwrap/releases 1.安装依赖包 [root@node3 ~]# yum install readline-devel ...
- 查看 oracle 序列号 用户名,查看oracle用户执行的sql语句历史记录
一时失误,删除了PL/SQL窗口数据的历史,然后半个半个星期写的代码全部白费,但是想起来之前执行过,所以可以通过查询历史记录找回.以下为找回代码: 平时用得少,保存一下以后查看. select * f ...
- 查看oracle操作历史记录
这两天在调试代码的时候,由于两个变量写反了,在数据比较多的时候,看不出异常,当查询结果只有一条数据的时候会返回空.由于变量比较多,所以直接看oracle的操作.一时半会忘了怎么写,这里记录下查看ora ...
- Oracle ASH查询活动会话历史记录
什么是活动会话历史记录(ASH) 活动会话历史记录(ASH)是Oracle 10g中引入的.它每秒对每个活动数据库会话的活动进行采样.数据保存在数据库内存中的缓冲区中.设计目标是保持约一个小时.如果会 ...
- 【转】Linux下Oracle sqlplus无法使用命令退格删除和历史记录的解决方法(使用rlwrap)...
文章转自:http://www.ha97.com/4856.html 作者: 谋万世全局者 PS:近来因工作需要业余在学习oracle,发现通过SecureCRT或putty等SSH客户端远程登录Li ...
- oracle某用户历史sql语句,查看oracle 用户执行的sql语句历史记录
select * from v$sqlarea t where t.PARSING_SCHEMA_NAME in ('用户名') order by t.LAST_ACTIVE_TIME desc se ...
- 查看oracle 用户执行的sql语句历史记录
select * from v$sqlarea t order by t.LAST_ACTIVE_TIME desc 注意 :执行此语句等等一些相关的语句 必须具有DBA 的权限 虽然这条语句很普通 ...
最新文章
- python asyncio教程_python中使用asyncio实现异步IO实例分析
- Linux 下 pmap 命令的使用
- 返回语句C语言return关键字
- 在 Mac 上多开微信,还能看到朋友撤回的信息:WeChatTweak
- 目录创建 android,创建目录浏览器 | Android 开发者 | Android Developers
- QML 实现图片帧渐隐渐显轮播
- TCP 和IP的区别
- how is odata metadata request served 故意把configuration file里的GM6改成GM61之后
- 使用Maven原型高效创建Eclipse模块
- React.js 入门与实战课程思维导图
- Linux下gSOAP的使用 (c++)
- 关于使用easyUI遇到过的一些坑
- 使用Swagger辅助开发Fabric Application的Web API
- Delphi Note
- 实例教你怎么使用s扫描器
- uniapp push推送服务使用指南
- android 阅读 翻页,极速PDF安卓版如何翻页、阅读模式修改等操作详解
- 车载系统升级、“特饭”会员品牌上线,解读新特背后的互联网产品逻辑...
- CStdioFile之ReadString()与WriteString()注意事项
- MongoDB中不溜教程(1)简介与命令
热门文章
- java中doloop语句_Java中的do-while循环——通过示例学习Java编程(11)
- yum install git Could not resolve host: ftp.twaren.net; Unknown error
- aptitude安装出现依赖_据说 pip install 今年将出现重大变化!
- python不完全支持面向对象程序设计_Python面向对象程序设计OOP入门教程【类,实例,继承,重载等】...
- 图书馆管理系统——超期付款
- loj#2340. 「WC2018」州区划分
- 组合数(codevs 1631)
- 2016年3-8,哦,好日子
- Ubuntu10.04中间Leach协议一键安装
- 【Photoshop】批处理与快捷批处理