请问如何查询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历史记录的更多相关文章

  1. 查看oracle的sql语句历史记录和锁表的情况

    查看oracle的sql语句历史记录和锁表的情况 (2012-01-04 20:59:59) 转载▼ 标签: 杂谈 分类: database 查询sql的历史记录 select * from v$sq ...

  2. 利用rlwrap配置linux下oracle sqlplus 历史记录回调

    .下载rlwrap wget http://utopia.knoware.nl/~hlub/uck/rlwrap/rlwrap-0.42.tar.gz .解压 tar -xvzf rlwrap-0.4 ...

  3. oracle sqlplus不支持上下键查看历史记录问题

    我们需要安装rlwrap软件 系统采样: [root@rac-2 src]# su - oracle Last login: Fri Mar 18 23:36:25 CST 2022 on pts/0 ...

  4. 查看oracle 用户执行的sql语句历史记录

      select * from v$sqlarea t order by t.LAST_ACTIVE_TIME desc

  5. 查看oracle用户执行的sql语句历史记录

    select PARSING_SCHEMA_NAME,COUNT(DISTINCT T.SQL_TEXT) from v$sqlarea t WHERE T.LAST_ACTIVE_TIME > ...

  6. oracle undo回滚段详解

    1.Undo是干嘛用的?   在介绍undo之前先说一下另外一个东西 transaction ,翻译成交易或事务.我们在进行一个事务的过程中需要申请许多资源,一个复杂的事务也需要很多步来完成.那么一个 ...

  7. Oracle库Delete删除千万以上普通堆表数据的方法

    需求:Oracle数据库delete删除普通堆表千万条历史记录. 直接删除的影响: 1.可能由于undo表空间不足从而导致最终删除失败的问题: 2.可能导致undo表空间过度使用,影响到其他用户正常操 ...

  8. Oracle体系结构详解

    对于一门技术的学习,尤其是像Oracle database这种知识体系极其庞杂的技术来讲,从宏观上了解其体系结构是至关重要的.同时,个人认为,未必是专业DBA人员才需要了解其体系结构(固然对于数据库专 ...

  9. oracle 归档日志

    归档日志(Archive Log)是非活动的重做日志备份.通过使用归档日志,可以保留所有重做历史记录,当数据库处于ARCHIVELOG模式并进行日志切换式,后台进程ARCH会将重做日志的内容保存到归档 ...

随机推荐

  1. MFC 直线 虚线 折线 圆 椭圆 矩形 弧形

    ****Dlg.h头文件加入: //为project加入画笔.点变量数组 public: CPen m_pen[5]; CPoint m_point[5]; public: void DrawLine ...

  2. Java基础:泛型及其擦除性、不可协变性

    转载请注明出处:jiq•钦's technical Blog 1泛型语法: 泛型类: class ClassName<T>{} 泛型方法:public <T> void f(T ...

  3. flask开发restful api

    flask开发restful api 如果有几个原因可以让你爱上flask这个极其灵活的库,我想蓝图绝对应该算上一个,部署蓝图以后,你会发现整个程序结构非常清晰,模块之间相互不影响.蓝图对restfu ...

  4. 在VC资源文件中加入声音资源

    本文介绍如何在VC资源文件中加入自己的声音资源,使自己的应用程序可以播放声音. 1.首先用文本编辑器(如记事本)打开资源文件(.rc文件) 在最后加入自己的声音资源,如下IDW WAVE " ...

  5. 提高mysql memory(heap) engine内存性能的开源补丁_XMPP Jabber即时通讯开发实践_百度空间

    提高mysql memory(heap) engine内存性能的开源补丁_XMPP Jabber即时通讯开发实践_百度空间 提高mysql memory(heap) engine内存性能的开源补丁

  6. oracle 之数据字典屣履造门。

     oracle 之数据字典屣履造门.(更新中)       今天是2013-06-20,哎,写这篇笔记的时候,我发现我是一个非常懒惰的人,这篇文章本该昨天就完成的,想起了钱鹤滩的<明日歌> ...

  7. Activity组件的生命周期

    一.Activiy组件的三个状态: 1.前台状态(active) : 在屏幕的最上层,页面获得焦点,可以响应用户的操作2.可视状态(paused) : 不能与用户交互,但是还存在于可视区域内,它依然存 ...

  8. Android中获取IMEI码

    Imei = ((TelephonyManager) getSystemService(TELEPHONY_SERVICE)) .getDeviceId(); 1.加入权限 在manifest.xml ...

  9. django-admin.py失效的问题合集!

    今早在命令行运行django-admin.py突然失效了.联想到昨天把Python的版本号由3.4降为2.7,Django由1.65降为1.5,能够是由于当中的修改造成的问题.网上搜了一下解决方式五花 ...

  10. Eclipse下Android编程代码自动提示

    在用Eclipse进行Android编程,为了代码自动提示,需要进行如下操作: 1.设置 java 文件的代码提示功能 打 开 Eclipse 依次选择 Window > Preferences ...