首页 数据库 Oracle oracle查看锁及session执行中的sql(总结分享)

oracle查看锁及session执行中的sql(总结分享)

Jul 01, 2022 pm 12:23 PM
oracle

本篇文章给大家带来了关于Oracle的相关知识,其中主要介绍了查看锁及session执行中的sql的相关问题,下面一起来看一下,希望对大家有帮助。

oracle查看锁及session执行中的sql(总结分享)

推荐教程:《Oracle视频教程

本文测试数据的数据库环境:Oracle 11g

           为什么说是session执行中的sql呢,某个session的sql执行记录好像获取不到,也看了很多的博文,网上很多有说通过视图v$active_session_history和v$sqlarea关联sql_id就能查询到某个session的sql执行记录,经过实践发现是不行的(通过表dba_hist_active_sess_history试过了也是不行),某些sql的sql_id在v$active_session_history根本就没有记录,我尝试修改参数:control_management_pack_access,发现我没有权限,而且我对了一下,参数值是正常的,该参数数据库是开启的,参考博文:Oracle V$ACTIVE_SESSION_HISTORY查询没有数据 - wazz_s - 博客园

        通过v$sqlarea视图能查询到sql的执行记录,但却查不到执行该sql的sessionid,如果有这个sessionid该多好,我就能查到那个人执行了该sql。

        如果我要查询导致锁表的那一条sql,网上大部分的博文都是这样教的,通过查询视图v$session得到对应的prev_sql_addr字段值,记为值A,然后通过值A作为视图v$sqlarea字段address的查询条件值,然后就可以查询到对应的sql记录了。这种作为练习测试你是可以找到找到锁表的sql,但是在正常生产环境下大部分情况下你是获取不到的,为什么呢,请看下文的介绍。

本文以探索的方式进行学习,为了保证数据的准确性,我开了三个数据库会话,分别记为session1、session2、session3,具体步骤如下:

1  在会话session1中新建测试表及测试数据

--新建测试表
create table zxy_table(zxy_id int,zxy_name varchar2(20));
--插入数据
insert into zxy_table(zxy_id,zxy_name) values(1,'zxy1');
insert into zxy_table(zxy_id,zxy_name) values(2,'zxy2');
insert into zxy_table(zxy_id,zxy_name) values(3,'zxy3');
insert into zxy_table(zxy_id,zxy_name) values(4,'zxy4');
commit;
登录后复制

2  查看session1的会话Id

 select userenv('sid') from dual;
登录后复制

可以看到会话Id为2546

3  在session1中,通过select  for update的对表zxy_table的某一行进行锁定,如下:

 select * from zxy_table where zxy_name='zxy1' for update;
登录后复制

4  在session2中,查询到该会话id为2189:

然后在session2中对表zxy_table值为zxy_name='zxy1'的行进行update,如下:

update zxy_table set zxy_name='zxy1_modify' where zxy_name='zxy1';
登录后复制

然后看到该sql已经被堵塞了,如下图:

5  然后我们来到会话session3查看锁表的情况了

首先查看表v$locked_object 

select * from v$locked_object;
登录后复制

 可以看到造成锁表的会话id为2546,就是前面的session1,同时object_id为110154,当然咯,在生成环境中,你看到的肯定不止一条记录,你要多执行几遍,执行n遍后,还能看到的记录,证明这条记录就是锁表的记录

通过object_id:110154查询dba4_objects表查询详细锁表的信息

select object_name as 被锁的表名称,obj.* from dba_objects obj where object_id='110154';
登录后复制

 通过sessionid:2546查询视图v$session

select 
       s.prev_sql_addr,
       module as 客户端工具名称,
       s.user# as 数据库账号名,
       s.osuser as 连接数据库客户端对应的window账号名称,
       s.machine as 连接数据库客户端对应的计算机名称,
       s.* 
from v$session s where sid='2546';
登录后复制
登录后复制

 得到prev_sql_addr的值为:000000012E045E28,然后通过得到的值查询视图v$sqlarea

select * from v$sqlarea where address='000000012E045E28';
登录后复制

 从上图中可以看到造成锁表的语句了,但是很多博文到了这一步就完事了,这样查询真的靠谱吗?答案是不靠谱的,你可以回到session1中随便执行一条sql ,如下:

 select * from zxy_table;
登录后复制

然后你再到session3执行

select 
       s.prev_sql_addr,
       module as 客户端工具名称,
       s.user# as 数据库账号名,
       s.osuser as 连接数据库客户端对应的window账号名称,
       s.machine as 连接数据库客户端对应的计算机名称,
       s.* 
from v$session s where sid='2546';
登录后复制
登录后复制

 再看看prev_sql_addr是不是变了,从000000012E045E28变为了00000001FB03CEC0,再通过00000001FB03CEC0查询视图v$sqlarea

select * from v$sqlarea where address='00000001FB03CEC0';
登录后复制

得到的sql_text是select * from zxy_table,你敢说这条sql导致了锁表吗?所有只能说是session1当前执行的sql,而且你很难保证session1执行完锁表的sql: select * from zxy_table where zxy_name='zxy1' for update且在提交前不再执行别的sql,这就是前文提出的问题的答案。

推荐教程:《Oracle视频教程

以上是oracle查看锁及session执行中的sql(总结分享)的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
4 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

oracle数据库日志会保存多久 oracle数据库日志会保存多久 May 10, 2024 am 03:27 AM

Oracle 数据库日志的保留期限取决于日志类型和配置,包括:重做日志:由 "LOG_ARCHIVE_DEST" 参数配置的最大大小决定。归档重做日志:由 "DB_RECOVERY_FILE_DEST_SIZE" 参数配置的最大大小决定。在线重做日志:不归档,在数据库重启时丢失,保留期限与实例运行时间一致。审计日志:由 "AUDIT_TRAIL" 参数配置,默认保留 30 天。

oracle中计算两个日期之间天数的函数 oracle中计算两个日期之间天数的函数 May 08, 2024 pm 07:45 PM

Oracle 中计算两个日期之间天数的函数是 DATEDIFF()。具体用法如下:指定时间间隔单位:interval(如 day、month、year)指定两个日期值:date1 和 date2DATEDIFF(interval, date1, date2) 返回天数差

oracle数据库启动步骤顺序为 oracle数据库启动步骤顺序为 May 10, 2024 am 01:48 AM

Oracle 数据库启动顺序为:1. 检查前置条件;2. 启动监听器;3. 启动数据库实例;4. 等待数据库打开;5. 连接到数据库;6. 验证数据库状态;7. 启用服务(如果需要);8. 测试连接。

oracle中interval的用法 oracle中interval的用法 May 08, 2024 pm 07:54 PM

Oracle 中的 INTERVAL 数据类型用于表示时间间隔,语法为 INTERVAL <精度> <单位>,可使用加减乘除运算操作 INTERVAL,适用于存储时间数据、计算日期差值等场景。

oracle中某个字符出现的次数怎么看出来 oracle中某个字符出现的次数怎么看出来 May 09, 2024 pm 09:33 PM

要在 Oracle 中查找字符出现的次数,执行以下步骤:获取字符串的总长度;获取字符所在子字符串的长度;计算字符出现的次数:用总长度减去子字符串长度。

oracle需要多少内存 oracle需要多少内存 May 10, 2024 am 04:12 AM

Oracle 所需内存量取决于数据库大小、活动水平和所需性能水平:用于存储数据缓冲区、索引缓冲区、执行 SQL 语句和管理数据字典缓存。具体数量受数据库大小、活动水平和所需性能水平影响。最佳实践包括设置适当的 SGA 大小、调整 SGA 组件大小、使用 AMM 和监控内存使用情况。

oracle数据库服务器硬件配置要求 oracle数据库服务器硬件配置要求 May 10, 2024 am 04:00 AM

Oracle 数据库服务器硬件配置要求:处理器:多核,主频至少 2.5 GHz,大型数据库建议 32 核以上。内存:小型数据库至少 8GB,中等规模 16-64GB,大型数据库或高负载工作负载高达 512GB 或更多。存储:SSD 或 NVMe 磁盘,RAID 阵列提高冗余和性能。网络:高速网络(10GbE 或更高),专用网卡,低延迟网络。其他:稳定电源、冗余组件、兼容操作系统和软件、散热和冷却系统。

oracle中替换字符串的方法 oracle中替换字符串的方法 May 08, 2024 pm 07:24 PM

Oracle 中替换字符串的方法是使用 REPLACE 函数,该函数的语法为:REPLACE(string, search_string, replace_string)。使用步骤:1. 识别要替换的子字符串;2. 确定替换子字符串的新字符串;3. 使用 REPLACE 函数进行替换。高级用法包括:多个替换、大小写敏感、特殊字符替换等。

See all articles