当前位置:  数据库>oracle

Oracle Lock 学习

    来源: 互联网  发布时间:2017-04-29

    本文导语: 1.显示Linux数据库中锁信息 select sid,addr kaddr,type,lmode,block from v$lock;       SID KADDR            TY      LMODE      BLOCK---------- ---------------- -- ---------- ----------         3 0000000077459298 XR          1          0   ...

1.显示Linux数据库中锁信息

select sid,addr kaddr,type,lmode,block from v$lock;

      SID KADDR            TY      LMODE      BLOCK
---------- ---------------- -- ---------- ----------
         3 0000000077459298 XR          1          0
         3 0000000077459368 RD          1          0
         3 0000000077459438 CF          2          0
         3 00000000774595D8 RS          2          0
       127 00000000774596A8 PW          3          0
       189 0000000077459778 RT          6          0
       196 0000000077459848 AE          4          0
       190 0000000077459918 AE          4          0
        66 00000000774599E8 TS          3          0
       127 0000000077459AB8 MR          4          0
       127 0000000077459B88 MR          4          0











       SID KADDR            TY      LMODE      BLOCK
---------- ---------------- -- ---------- ----------
       127 0000000077459C58 MR          4          0
       127 0000000077459D28 MR          4          0
       127 0000000077459DF8 MR          4          0
       191 0000000077459EC8 AE          4          0
       191 0000000077459FB0 TX          0          0
       133 000000007745A080 AE          4          0
       196 00007F913A138DE0 TM          3          0
       191 00007F913A138DE0 TM          3          0
       196 0000000076034228 TX          6          1









2.持有锁session 196 信息

执行语句
SQL> update dept set dname='sale' where deptno='30';

1 row updated.

SQL> SELECT SID FROM V$MYSTAT WHERE ROWNUM =1;

       SID
----------
       196

SQL> select sid,username from v$session where sid in
  2  (select sid from v$lock where block=1);

       SID USERNAME
---------- ------------------------------
       196 SYS

3.显示争用锁session 191的 SID,username,ID1,执行SQL语句
争用session执行语句
SQL> update dept set dname='sale' where deptno='30';
session 191无法获得RX锁,等待持有锁session 196释放RX


select B.sid,b.username,D.id1,a.sql_text
from v$session b,v$lock D,v$sqltext A
where B.lockwait=d.kaddr
and a.address=b.sql_address
and a.hash_value=b.sql_hash_value;




       SID USERNAME                              ID1 SQL_TEXT
---------- ------------------------------ ---------- ----------------------------------------------------------------
       191 SYS                                393226 update dept set dname='sale' where deptno='30'



4.显示锁会话进程信息

SELECT s.oSUSEr "os_user",
s.username "user",
s.sid "sid",
s.serial# "serial#",
s.process "pid",
s.status "status",
l.name "Object_locked",
l.mode_held "lock Held"
FROM v$session s,dba_dml_locks l,v$process p
where l.session_id = s.sid and p.addr=s.paddr;








os_user                        user                                  sid    serial# pid                      status   Object_locked                  lock Held
------------------------------ ------------------------------ ---------- ---------- ------------------------ -------- ------------------------------ -------------
Oracle                         SYS                                   196         25 4549                     INACTIVE DEPT                           Row-X (SX)
oracle                         SYS                                   191         19 4867                     ACTIVE   DEPT                           Row-X (SX)


持有TX 196 session status为inactive,想要获得TX锁191 session status 为Active
 

5.kill Session

可以选择杀掉连个中的任何一个session,以保证更新成功。
SQL> alter system kill session 'sid,serial#';
SQL> alter system kill session '196,25';


    
 
 

您可能感兴趣的文章:

  • 循序渐进学习Oracle数据库
  • Linux+Oracle学习笔记
  • 想在linux下学习oracle,有经验的高手们给点建议。
  • Oracle 10G进程体系学习笔记
  • 怎样学习oracle
  • Linux 下 Oracle 命令学习笔记
  • oracle使用sql脚本生成csv文件案例学习
  • oracle 技巧学习笔记
  • 想学习UNIX,LINUX,ORACLE方面的知识。请帮忙。
  • 我该如何学习Linux和Oracle?
  • Oracle数据库基本知识学习笔记
  • 学习登录oracle数据库时常用的操作命令
  • 技巧学习 在Python环境下连接Oracle数据库
  • Oracle 数据库学习入门心得
  • Oracle与MySQL学习体会比较
  • oracle数据库学习
  • oracle数据库的学习体会
  • Oracle数据库入门学习经验分享
  • 数据库 iis7站长之家
  • 学习Linux下Oracle数据库编程
  • [Oracle] 浅谈Lock与Latch
  • Linux Oracle 设置LOCK_SGA
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • Oracle 数据库开发工具 Oracle SQL Developer
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • Oracle EBS R12 支持 Oracle Database 11g
  • Oracle 10g和Oracle 11g网格技术介绍
  • SCO unix下安装oracle,但没有光盘,请大家推荐一个oracle下载站点(unix版本的)。谢谢!!!!
  • oracle中如何把表中具有相同值列的多行数据合并成一行
  • 请问大家用oracle数据库, 用import oracle.*;下的东西么? 还是用标准库?
  • Oracle 数据库(oracle Database)性能调优技术详解
  • Linux /$ORACLE_HOME $ORACLE_HOME
  • ORACLE日期相关操作
  • Linux系统下Oracle的启动与Oracle监听的启动
  • ORACLE数据库常用字段数据类型介绍
  • 请问在solaris下安装ORACLE,用root用户和用oracle用户安装有什么区别么?
  • Oracle 12c的九大最新技术特性介绍
  • 网间Oracle的连接,远程连接Oracle服务器??


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,