Oracle数据库查看锁表语句和解锁的方法示例

 更新时间:2023年10月11日 11:36:39   作者:何以解忧,唯有..  
在DBA的日常工作中,经常遇到为Oracle用户解锁的操作,这篇文章主要给大家介绍了关于Oracle数据库查看锁表语句和解锁的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下

一、查看锁表语句

SELECT
	sess.sid,
	sess.serial#,
	lo.oracle_username, -- 登陆账号名称
	lo.os_user_name,    -- 登录电脑名称
	ao.object_name,     -- 被锁表名
	lo.locked_mode      -- 死锁级别
FROM
	v$locked_object lo,
	dba_objects ao,
	v$session sess 
WHERE
	ao.object_id = lo.object_id 
	AND lo.session_id = sess.sid;

死锁级别:

级别描述
0none
1null 空
2Row-S 行共享(RS):共享表锁
3Row-X 行专用(RX):用于行的修改
4Share 共享锁(S):阻止其他DML操作
5S/Row-X 共享行专用(SRX):阻止其他事务操作
6exclusive 专用(X):独立访问使用

二、解锁语句

alter system kill session '68,51'; -- 分别为SID和SERIAL#号

三、查看引起锁表的Sql语句

SELECT
	A.USERNAME,
	A.MACHINE,
	A.PROGRAM,
	A.SID,
	A.SERIAL#,
	A.STATUS,
	C.PIECE,
	C.SQL_TEXT 
FROM
	V$SESSION A,
	V$SQLTEXT C 
WHERE
	A.SID IN ( SELECT DISTINCT T2.SID FROM V$LOCKED_OBJECT T1, V$SESSION T2 WHERE T1.SESSION_ID = T2.SID ) 
	AND A.SQL_ADDRESS = C.ADDRESS ( + ) 
ORDER BY
	C.PIECE;

如何避免锁表

常见问题是用户更新操作没有提交事务,所以:如果单独更新操作,需要写2个操作 SQL,一个是更新操作SQL语句,另一个是commit语句提交事务。

总结 

到此这篇关于Oracle数据库查看锁表语句和解锁的文章就介绍到这了,更多相关Oracle查看锁表和解锁内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Oracle数据库的实例/表空间/用户/表之间关系简单讲解

    Oracle数据库的实例/表空间/用户/表之间关系简单讲解

    这篇文章主要介绍了Oracle数据库的实例/表空间/用户/表之间关系简单讲解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • 关于Oracle listener日志解析利器的使用方法

    关于Oracle listener日志解析利器的使用方法

    这篇文章主要跟大家分享了关于Oracle listener日志解析利器的使用方法,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-03-03
  • oracle 视图权限 oracle 创建视图权限不足

    oracle 视图权限 oracle 创建视图权限不足

    在scott用户下创建视图的时候,报错:权限不足,遇到这个问题,我也是束手无策,于是网上搜集整理了一下,晒出来和大家分享,希望可以帮助你们
    2012-11-11
  • Oracle CBO几种基本的查询转换详解

    Oracle CBO几种基本的查询转换详解

    这篇文章主要介绍了Oracle CBO几种基本的查询转换详解,包含视图合并、子查询解嵌套、谓语前推、物化视图查询重写等内容,需要的朋友可以参考下
    2014-07-07
  • Oracle分析函数用法详解

    Oracle分析函数用法详解

    本文详细讲解了Oracle分析函数的用法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-05-05
  • Oracle递归查询start with connect by prior的用法

    Oracle递归查询start with connect by prior的用法

    这篇文章主要给大家介绍了关于Oracle递归查询start with connect by prior、的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-02-02
  • Oracle数据泵(expdp)导入导出数据的详细步骤

    Oracle数据泵(expdp)导入导出数据的详细步骤

    这篇文章主要介绍了Oracle数据泵(expdp)导入导出数据的详细步骤,文中详细描述了源数据库操作中的数据备份和目标数据库操作中的数据恢复过程,需要的朋友可以参考下
    2024-12-12
  • oracle大数据删除插入方式

    oracle大数据删除插入方式

    本文介绍了在Oracle数据库中高效进行大数据插入和删除操作的方法,对于插入操作,通过并行查询可以显著提高性能;对于删除操作,使用游标和批量处理可以避免长时间锁定和资源争用,文章还提供了性能优化建议、常见问题及解决方案,并总结了在实际操作中需要注意的点
    2025-01-01
  • oracle中 procedure(存储过程)和function(函数)本质区别

    oracle中 procedure(存储过程)和function(函数)本质区别

    这篇文章主要介绍了 oracle中 procedure(存储过程)和function(函数)本质区别,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-02-02
  • Linux系统下导出ORACLE数据库出现Exporting questionable statistics.错误 处理

    Linux系统下导出ORACLE数据库出现Exporting questionable statistics.错误 处理

    Linux系统下导出ORACLE数据库出现Exporting questionable statistics.错误 处理...
    2007-03-03

最新评论