一、要找出最耗资源的sql

我们可以首先使用top等工具,找到最好资源的进程(记住进程号),例如,操作系统进程号为2796,然后根据这个进程号(v$process.spid)在v$process中找到进程地址(v$process.addr),然后根据这个地址在v$session中找到相应的sid(v$session.sid),然后根据这个sid找到相应的hash alue(v$session. sql_hash_value),然后根据这个hash alue在v$sqltext,$sql,v$sqlarea等视图中找到对应的sql语句(sql_text)。

  select * from v$process where spid='2796';

  select sql_hash_value,machine,username,program from v$session where PAddr='63B7A584';

  select * from v$sqltext where hashvalue='833203018';

  select * from v$sql where hashvalue='833203018';

  select * from v$sqlarea where hashvalue='833203018';

  SELECT a.username,a.machine,a.program,a.sid,a.serial#,a.status,c.piece,c.sql_text FROM v$session a,v$process b,v$sqltext c WHERE b.spid='2796' AND b.addr=a.paddr AND a.sql_address=c.address(+) ORDER BY c.piece

 ============================================

 select sql_text
from v$sqltext
where (hash_value,sql_address) in
(
select decode(sql_hash_value,0,prev_hash_value,sql_hash_value),
          decode(sql_hash_value,0,prev_sql_addr,sql_address)
from v$session
where paddr = (select addr from v$process where spid='操作系统进程id')
)

=================================================

二、oracle 被锁问题集及解决方案

 

 1.错误信息:ORA-28000: the account is locked

原因分析: The user has entered wrong password consequently for maximum number of times specified by the user's profile parameter FAILED_LOGIN_ATTEMPTS, or the DBA has locked the account
解决办法: Wait for PASSWORD_LOCK_TIME or contact DBA

              2.视图被锁住的问题

解决的办法:

1.找出等待事件的原因
select event,p1,p2,sid from v$session_wait where event not like 'SQL%' and event not like 'rdbms%';
2.找出锁住的进程
select object_id,session_id,locked_mode from v$locked_object;
3.找出锁住的进程的操作系统进程
select spid from v$process where addr=(select paddr from v$session where sid=144);(这个19表示被锁定的SID)
4.
4.在操作系统上删除进程
orakill eoffice 2768(第一个参数据是数据库的SID  第二个参数是进程ID,这个数字就是上面取到的进程ID,这个是在Dos命令窗口下操作)

下面是一个操作实例
首先先Drop 相关的锁定的对象如Drop View vw_wf_CritCondition,然后结束PL/SQL Dev 再开一次才能执行下面的操作。

SQL> select event,p1,p2,sid from v$session_wait where event not like 'SQL%' and event not like 'rdbms%';

EVENT                                                                    P1         P2        SID
---------------------------------------------------------------- ---------- ---------- ----------
null event                                                       1413697536          1         18
null event                                                                1      95552         22
pmon timer                                                              300          0          1
smon timer                                                              300          0          5
library cache lock                                                763239564  792075180         23   (这里表示有一个库被锁掉了。)
wakeup time manager                                                       0          0          8

6 rows selected

SQL> select object_id,session_id,locked_mode from v$locked_object;

 OBJECT_ID SESSION_ID LOCKED_MODE
---------- ---------- -----------
        77         22           3
        69         22           3
        70         22           3
       316         22           3
       314         22           3
       356         22           3
        68         22           3
        72         22           3
        73         22           3
        74         22           3
        75         22           3

11 rows selected

SQL> select spid from v$process where addr=(select paddr from v$session where sid=22);

SPID
------------
3348

在Dos操作,而且只能在安装数据的本机操作
orakill eoffice 3348

 

3.查出Oracle 数据库中的锁等待

首先,以 dba 身份(不一定为system)登录入数据库中,创建三个基本表:my_session,my_lock, my_sqltext,并在将会进行查询的列上建立相应的索引。语句如下: rem 从 v$session 视图中取出关心的字段,创建 my_session 表,并在查询要用到的字段上创建索引,以加快查询速度

drop table my_session;
create table my_session
as
select a.username, a.sid, a.serial#,
a.lockwait, a.machine,a.status,
a.last_call_et,a.sql_hash_value,a.program
from v$session a
where 1=2 ;

create unique index my_session_u1 on my_session(sid);
create index my_session_n2 on my_session(lockwait);
create index my_session_n3 on my_session(sql_hash_value);

---- rem 从 v$lock 视图中取出字段,创建 my_lock 表,并在查询要用到的字段上创建索引,以加快查询速度
drop table my_lock;
create table my_lock
as
select id1, kaddr, sid, request,type
from v$lock
where 1=2;

create index my_lock_n1 on my_lock(sid);
create index my_lock_n2 on my_lock(kaddr);

---- rem 从 v$sqltext 视图中取出字段,创建 my_sqltext 表,并在查询要用到的字段上创建索引,以加快查询速度
drop table my_sqltext;
create table my_sqltext
as
select hash_value , sql_text
from v$sqltext
where 1=2;

create index my_sqltext_n1 on my_sqltext ( hash_value);

---- 然后,创建一个 SQL 脚本文件,以便需要时可从 SQL*Plus 中直接调用。其中,首先用 truncate table 表名命令将表中的记录删除。之所以用 truncate 命令,而不是用delete 命令,是因为delete 命令执行时,将会产生重演记录,速度较慢,而且索引所占的空间并未真正释放,若反复做 insert及delete,则索引所占的空间会不断增长,查询速度也会变慢。而 truncate命令不产生重演记录,速度执行较delete快,而且索引空间被相应地释放出来。删除记录后,再将三个视图中的相关记录插入自己创建的三个表中。最后,对其进行查询,由于有索引,同时由于在插入时条件过滤后,记录数相对来说较少,因而查询速度很快,马上可以看到其结果。
---- 此时,若发现该阻塞其它用户进程的进程是正常操作中,则可通知该用户对其进行提交,从而达到释放锁资源的目的;若为未正常操作,即,其状态为"inactive",且其last_call_et已为较多长时间,则可执行以下语句将该进程进行清除,系统会自动对其进行回滚,从而释放锁住的资源。

alter system kill session 'sid, serial#';
---- SQL 脚本如下:
set echo off
set feedback off
prompt '删除旧记录.....'
truncate table my_session;
truncate table my_lock;
truncate table my_sqltext;

prompt '获取数据.....'
insert into my_session
select a.username, a.sid, a.serial#,
a.lockwait, a.machine,a.status,
a.last_call_et,a.sql_hash_value,a.program
from v$session a
where nvl(a.username,'NULL')< >'NULL;

insert into my_lock
select id1, kaddr, sid, request,type
from v$lock;

insert into my_sqltext
select hash_value , sql_text
from v$sqltext s, my_session m
where s.hashvalue=m.sql_hash_value;

column username format a10
column machine format a15
column last_call_et format 99999 heading "Seconds"
column sid format 9999

prompt "正在等待别人的用户"
select a.sid, a.serial#,
a.machine,a.last_call_et, a.username, b.id1
from my_session a, my_lock b
where a.lockwait = b.kaddr;

prompt "被等待的用户"
select a.sid, a.serial#,
a. machine, a.last_call_et,a.username,
b. b.type,a.status,b.id1
from my_session a, my_lock b
where b.id1 in
(select distinct e.id1
from my_session d, my_lock e
where d.lockwait = e.kaddr)
and a.sid = b.sid
and b.request=0;

prompt "查出其 sql "
select a.username, a.sid, a.serial#,
b.id1, b.type, c.sql_text
from my_session a, my_lock b, my_sqltext c
where b.id1 in
(select distinct e.id1
from my_session d, my_lock e
where d.lockwait = e.kaddr)
and a.sid = b.sid
and b.request=0
and c.hash_value =a.sql_hash_value;

---- 以上思路也可用于其它大型数据库系统如 Informix, Sybase,DB2中。通过使用该脚本,可以极大地提高获取系统中当前锁等待的情况,从而及时解决数据库应用系统中的锁等待问题。而且,由于实际上已取出其 program 名及相应的 sql 语句,故可以在事后将其记录下来,交给其开发人员进行分析并从根本上得到解决

 

source:http://dolphin-ygj.javaeye.com/blog/362501

 

转载于:https://blog.51cto.com/comtv/385120

找出最耗资源的sql ----没明白相关推荐

  1. oracle查询哪个sql占用资源,查询oracle最耗资源的sql语句

    1.查询当前系统中正在执行的sql: SELECT osuser, username, sql_text from v$session a, v$sqltext b where a.sql_addre ...

  2. 查询oracle最耗资源的sql语句

    1.查询当前系统中正在执行的sql: SELECT osuser, username, sql_text from v$session a, v$sqltext b  where a.sql_addr ...

  3. 【JVM性能调优】使用jstack找出最耗CPU的java线程

    jstack可以定位到线程堆栈,根据堆栈信息我们可以定位到具体的代码,所以它在JVM性能调优中很常见.下面我们在找出某个java进程中最耗CPU的线程,并定位堆栈信息,使用到的命令有:ps.top.p ...

  4. JVM调优之jstack找出最耗cpu的线程并定位代码

    jstack可以定位到线程堆栈,根据堆栈信息我们可以定位到具体代码,所以它在JVM性能调优中使用得非常多.下面我们来一个实例找出某个Java进程中最耗费CPU的Java线程并定位堆栈信息,用到的命令有 ...

  5. 找出存在性能问题的sql语句

    SELECT  creation_time  N'语句编译时间'           ,last_execution_time  N'上次执行时间'           ,total_physical ...

  6. AB列对比,怎样找出A列中有B列没有的

    一.首先打开Excel表格 二.然后在C1单元格输入如下公式,按下回车 注意如下公式是从A1首行开始对比的,若首行为title,从第二行开始比较,则修改公式中A1为A2 =IF(COUNTIF(B:B ...

  7. activiti如何最后一次提交事务_MySQL如何找出未提交事务的SQL浅析

    很久之前曾经总结过一篇博客"MySQL如何找出未提交事务信息",现在看来,这篇文章中不少知识点或观点都略显肤浅,或者说不够深入,甚至说部分结论是错误的.下面重新探讨一下这个话题.那 ...

  8. mysql未提交事务sql_MySQL如何找出未提交事务的SQL浅析

    --准备测试环境数据(实验环境为MySQL 8.0.18社区版)mysql> create table kkk(id int , name varchar(12));Query OK, 0 ro ...

  9. 故障申报系统php源码,运维不再专业救火 不会PHP照样找出代码性能问题

    作者: 凉白开 网站:www.ttlsa.com 身处互联网的SA(运维)们总感叹自己职业的苦逼,Why?我来告诉你:APP奔溃.网站打不开.网站502.搜索缓慢.应用卡顿通通找运维,运营.项目经理. ...

  10. linux+平均磁盘请求数量_Linux 查看磁盘IO并找出占用IO读写很高的进程

    背景-线上告警 线上一台服务器告警,磁盘利用率 disk.util > 90,并持续告警. 登录该服务器后通过 iostat -x 1 10 查看了相关磁盘使用信息.相关截图如下: # 如果没有 ...

最新文章

  1. 009_Raphael绘制图形
  2. C# WinForm ProgressBar垂直显示进度和从右向左显示进度
  3. Python中__str__和__repr__
  4. java关联查询实战_MapReduce实战(五)实现关联查询
  5. 已经创建了AWS EC2实例,Linux系统默认没有root用户,那么如何创建root用户并更改为root用户登录呢?
  6. 前端内存优化的探索与实践
  7. Python语法入门
  8. 开发中,常用到的Eclipse快捷键
  9. 获取TextView每行的内容 (涉及getLineCount为0,getLineEnd问题)
  10. DRF parser请求流程
  11. MyEclipse could not redeploy(不能重新部署)的解决办法
  12. 基于matlab和lingo的数学实验,MATLAB和LINGO软件在数学建模竞赛中的应用-精选教育文档...
  13. java二进制流_java读写二进制流
  14. Java基础 实验二:类和对象
  15. 全国计算机四六级报名时间,2018年6月四六级考试报名即将截止,请抓紧时间报名!...
  16. 【JSP笔记02】JSP注释、脚本、表达式、JSP三大指令、JSP七大动作的介绍及使用
  17. VAM语料库--学习笔记
  18. python蒙特卡洛_Python:从零开始的汉密尔顿蒙特卡洛
  19. 计算机导论部分知识整理
  20. 智能照明新的低成本解决方案?涂鸦 Beacon 智能灯泡初体验

热门文章

  1. java http 工具类_Java发送Http请求工具类
  2. java编程语言的常用快捷方式
  3. 帆软控件焦点事件设置可用性
  4. c++ 标准异常类层次结构_详解Java异常
  5. HDU-1159-Common Subsequence
  6. 这次是16.7亿元!新能源汽车骗补何时休?
  7. Openresty 学习笔记(二)Nginx Lua 正则表达式相关API
  8. PLSC(Partial Least Square Correlation)偏最小二乘相关
  9. 实体框架 6.0:异步、IQueryable操作符和特性改进
  10. wcf中的几个配置问题