㈠ 如何查询oracle操作记录的sql
select * from v$sqlarea t where t.PARSING_SCHEMA_NAME in ('用户名') order by t.LAST_ACTIVE_TIME desc
用户名需要大写
select * from v$sqlarea t order by t.LAST_ACTIVE_TIME desc
注意 :执行此语句等等一些相关的语句 必须具有DBA 的权限 虽然这条语句很普通 但是需要的时候很管用 能够及时查出一个人执行sql语句情况
-------oracle 查看已经执行过的sql 这些是存在共享池中的 --------->
select * from v$sqlarea t order by t.LAST_ACTIVE_TIME desc
-----------查看oracle会话----------------------------》
select * from v$session t order by t.LAST_ACTIVE_TIME desc
-------------查看oracle的权限角色------------------------------>
select * from dba_role_privs; 授予用户和其他角色的角色
select * from dba_sys_privs; 授予用户和其他角色的系统权限
select * from dba_tab_privs; 数据库中对象的所有授权
select * from user_role_privs; 查看当前用户的角色
㈡ 怎样查看ORACLE执行过的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 b
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 A LEFT JOIN V$SQL B 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数据库的操作记录
用sys用户以dba身份登录。
然后,查看视图:V_$SQL,如下参考:
select*
fromV_$SQLt
WHEREt.SERVICE='orcl'
andt.PARSING_SCHEMA_NAME='BHOA'
ANDT.SQL_TEXTLIKE'update%'
orderbyt.LAST_ACTIVE_TIME
可直接查出当前update的那条sql语句。从语句中可看出对什么表进行了什么操作。
㈣ oracle如何查出历史记录中执行效率低的SQL语句
如果你用的是oracle 10g的话,这个有种很简单的方法就是查看awr报告。
很简单,你登陆到服务器的操作系统,进入到$ORACLE_HOME/rdbms/admin目录下。然后sqlplus "/as sysdba"登陆到数据库,执行
@awrrpt.sql;
然后按照提示一步一步做,注意格式选html(这样方便你阅读)。最后会让你命名这个文件。
完了之后,你把那个文件拷贝到本地用IE打开就看到了。里面有很详细的,包括这段时间占CPU,IO,等等最严重的SQL排行。很好很强大。
-------------------------
至于你说查看当前的sql,你在v$session里查看长期blocking别人的session ID,然后根据这个session id从v$text里就能查到这个sql了。
-------------------------
很明确了吧
㈤ Oracle_Sql语句
你的Where条件里面的Or用得太多了,用In试试吧,Oracle在10G以后对In优化后效果还是挺好的,实在不行就改用exists来改写条件
㈥ oracle 中怎样查看以前执行过的SQL语句是否有锁
用如下语句查询:
select'blocker('||lb.sid||':'||sb.username||')-sql:'||qb.sql_textblockers,'waiter('||lw.sid||':'||sw.username||')-sql:'||qw.sql_textwaitersfromv$locklb,v$locklw,v$sessionsb,v$sessionsw,v$sqlqb,v$sqlqwwherelb.sid=sb.sidandlw.sid=sw.sidandsb.prev_sql_addr=qb.addressandsw.sql_address=qw.addressandlb.id1=lw.id1andsw.lockwaitisnotnullandsb.lockwaitisnullandlb.block=1;
如果有被锁的sql,查询中有结果:
㈦ oracle 中怎样查看以前执行过的SQL语句
您好,我来为您解答:
可以通过logminer分析日志文件
查询某时间段执行过的语句。
如果我的回答没能帮助您,请继续追问。
㈧ 查看oracle数据库最近执行了哪些sql语句
在oracle上看的话,只能启用sql trace了,尽量在数据库用户、操作比较少的时候做,否则会混入很多别的用户或程序执行的语句。
简单一点是在应用程序中写sql语句的日志。
㈨ oracle的日志能找到之前执行过的sql语句吗
最直接的办法就是打开SQL_TRACE: alter session set SQL_TRACE=true;(要DBA权限) 然后到服务器上追踪文件里面查看这个session执行了哪些SQL,不过这是session级的. 也可以使用系统级的. 对系统性能有影响
㈩ oracle中SQL语句
insert into task(startdate) values(to_date('2003-5-4','YYYY-MM-DD'))
date数据类型进入库的时候,要to_date一下