ORACLE 如何查询被锁定表及如何解锁释放session

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ORACLE 如何查询被锁定表及如何解锁释放session相关的知识,希望对你有一定的参考价值。

参考技术A

ORACLEEBS操作某一个FORM界面,或者后台数据库操作某一个表时发现一直出于"假死"状态,可能是该表被某一用户锁定,导致其他用户无法继续操作。

拓展资料:

Session:在计算机中,尤其是在网络应用中,称为“会话控制”。Session对象存储特定用户会话所需的属性及配置信息。这样,当用户在应用程序的Web页之间跳转时,存储在Session对象中的变量将不会丢失,而是在整个用户会话中一直存在下去。当用户请求来自应用程序的Web页时,如果该用户还没有会话,则Web服务器将自动创建一个Session对象。当会话过期或被放弃后,服务器将终止该会话。Session对象最常见的一个用法就是存储用户的首选项。例如,如果用户指明不喜欢查看图形,就可以将该信息存储在Session对象中。有关使用Session对象的详细信息,请参阅“ASP应用程序”部分的“管理会话”。注意会话状态仅在支持cookie的浏览器中保留。

参考资料:session百度百科


Oracle查询被锁的表及解锁方法

1.用下列sql语句查询操作不当引起锁表的进程的SESSION_ID及USERNAME

SELECT S.SID SESSION_ID, S.USERNAME, DECODE(LMODE, 0, ‘None’, 1, ‘Null’, 2, ‘Row-S (SS)’, 3, ‘Row-X (SX)’, 4, ‘Share’, 5, ‘S/Row-X (SSX)’, 6, ‘Exclusive’, TO_CHAR(LMODE)) MODE_HELD, DECODE(REQUEST, 0, ‘None’, 1, ‘Null’, 2, ‘Row-S (SS)’, 3, ‘Row-X (SX)’, 4, ‘Share’, 5, ‘S/Row-X (SSX)’, 6, ‘Exclusive’, TO_CHAR(REQUEST)) MODE_REQUESTED, O.OWNER||’.’||O.OBJECT_NAME||’ (‘||O.OBJECT_TYPE||’)’, S.TYPE LOCK_TYPE, L.ID1 LOCK_ID1, L.ID2 LOCK_ID2 FROM V$LOCK L, SYS.DBA_OBJECTS O, V$SESSION S WHERE L.SID = S.SID AND L.ID1 = O.OBJECT_ID;
假设查询列表如下:

1XXXX U001 ……………………………………..

2XXXX U002 ……………………………………..

3XXXX U003 ……………………………………..

2.将SESSION_ID及USERNAME做为条件查找出serial#

select sid, serial# from v$session where sid=’1XXXX’ and username=’U001′;

假设查询列表如下:

1XXXX adfadfadf

3.通过以上查询知道了sid和 SERIAL#就可以开杀了
alter system kill session ‘1XXXX ,adfadfadf’;



以上是关于ORACLE 如何查询被锁定表及如何解锁释放session的主要内容,如果未能解决你的问题,请参考以下文章

ORACLE 如何查询被锁定表及如何解锁释放session

ORACLE 如何查询被锁定表及如何解锁释放session

Oracle查询被锁的表及解锁方法

Oracle账号被锁定如何解锁

Oracle数据库老是被锁表,而且用解锁语句解开后,紧跟着又出来一堆锁,解也解不完

如何解锁Oracle数据库中账号