Oracle锁
admin
2023-04-14 09:41:31
0

1、定义:

锁(lock)机制用于管理对共享资源的并发访问(使对这些共享资源的并发性访问串行化),同时还能提供数据完整性和一致性。

2、Oracle锁特征:

Oracle中锁不是稀有资源;

Oracle不会自动升级锁,永远不会;

 Oracle 中,行级锁没有相关的开销

3、Oracle锁分类

DML

DDL

内部锁或LATCH

4、锁一览图

锁代码

锁模式名称

锁模式简写

锁模式级别

备注说明

隐式产生锁

显式产生锁

0

None

None


无锁模式,select操作便是这样的情况



1

Null

Null

表级锁

Oracle在内存中自动加的锁,主要起通知作用



2

Row-S

SS

表级锁


10g版本前:FOR UPDATE

LOCK TABLE 表名 IN ROW SHARE MODE;

3

Row-SX

SX

表级锁

行级排它锁,主要由DML语句引起

10g版本后:FOR UPDATEDML语句

LOCK TABLE 表名 IN ROW EXCLUSIVE MODE;

4

Share

S

表级锁

共享锁、只读锁


LOCK TABLE 表名 IN  SHARE MODE;

5

S/Row-X

SSX

表级锁

共享行排它锁


LOCK TABLE 表名 IN SHARE ROW EXCLUSIVE MODE;

6

Exclusive

X

表级锁/行级锁

排它锁



RRow  SShare XExclusive


5、TM锁兼容性


N

SS

SX

S

SSX

X

N

YES

YES

YES

YES

YES

YES

SS

YES

YES

YES

YES

YES

NO

SX

YES

YES

YES

NO

NO

NO

S

YES

YES

NO

YES

NO

NO

SSX

YES

YES

NO

NO

NO

NO

X

YES

NO

NO

NO

NO

NO


6、锁常用sql

--测试子表:成绩表

SELECT * FROM score;

--测试父表:学生信息表

SELECT * FROM student;

--查询当前会话值

SELECT * FROM v$mystat WHEREROWNUM='1';

--动态性能视图 v$locked_object 各字段的含义

SELECT l.XIDUSN         AS回滚段号,

      l.XIDSLOT         AS回滚槽号,

      l.XIDSQN          AS回滚序列号,

      l.OBJECT_ID       AS被锁对象ID,

      l.SESSION_ID      AS持有锁对象会话ID,

      l.ORACLE_USERNAME AS持有锁的oracle用户名,

      l.OS_USER_NAME    AS持有锁操作系统用户名,

      l.PROCESS         AS操作系统进程号,

      l.LOCKED_MODE     AS锁模式

  FROM v$locked_object l;

--当前用户创建的所有对象,列出部分常用字段含义

SELECT uo.object_name AS对象名称,

      uo.object_id   AS对象ID,

       uo.object_typeAS对象类型

  FROM user_objects uo;

--通过v$locked_object与user_objects两表关联可以得出被锁的是哪个表以及是被哪个用户锁的

SELECT uo.object_name   AS对象名称,

      uo.object_type    AS对象类型,

      l.ORACLE_USERNAME AS持有锁的oracle用户名,

      l.LOCKED_MODE     AS锁模式

  FROM v$locked_object l,user_objects uo

 WHERE l.OBJECT_ID =uo.object_id;

/* AND l.SESSION_ID=&session_id;*/

--查询所有正在等待获得锁的会话ID及锁类型

SELECT w.waiting_session AS等待锁的会话ID,

      w.holding_session AS持有锁的会话ID,

      w.lock_type       AS锁类型,

      w.mode_held       AS锁机制

  FROM dba_waiters w;

--动态性能视图事务执行列表(未提交状态),BLOCK=1是堵塞者,BLOCK=0是被堵塞者

SELECT * FROM v$transaction_enqueue;

--查询阻挡关系

SELECT (SELECT s.USERNAME FROM v$session s WHERE s.SID = a.SID) AS阻挡者名,

       a.SID AS阻挡者会话ID,

       '正在阻挡'AS行为,

       (SELECT s.USERNAME FROM v$session s WHERE s.SID = b.SID) AS被阻挡者名,

       b.SID AS被阻挡者会话ID

  FROM v$lock a, v$lock b

 WHERE a.ID1 = b.ID1

   AND a.ID2 = b.ID2

   AND a.BLOCK = 1

   AND b.REQUEST > 0;

--根据会话ID查询前一步sql操作语句,这个语句不适合应用程序

SELECT sq.sql_text

  FROM v$sql sq

 WHERE sq.SQL_ID =

       (SELECT s.SQL_ID FROM v$session s WHERE s.SID =&session_id);


相关内容

热门资讯

【第一消息】“新战皇牛牛有挂吗... 网上科普关于“新战皇牛牛有没有挂”话题很是火热,小编也是针对新战皇牛牛作*弊开挂的方法以及开挂对应的...
今日重大发现“微乐掼蛋究竟有挂... 有 亲,根据资深记者爆料微乐掼蛋是可以开挂的,确实有挂(咨询软件无需打开...
全栈自主可控,三岳数维携手鸿蒙...   近年来,深圳市加快打造工业软件与人工智能产业高地,在此背景下,龙岗区积极响应市委市政府部署,并在...
今日重大通报“衡阳丫丫竞技有没... 有 亲,根据资深记者爆料衡阳丫丫竞技是可以开挂的,确实有挂(咨询软件无需...
我来教教您“佛手在线是不是有挂... 我来教教您“佛手在线是不是有挂?”(太坑了原来有挂)您好,佛手在线这个游戏其实有挂的,确实是有挂的,...
最新引进“国民麻将真的有挂吗?... 最新引进“国民麻将真的有挂吗?”(太坑了原来有挂)您好,国民麻将这个游戏其实有挂的,确实是有挂的,需...
重磅消息“葫芦三娃辅助器?”(... 网上科普关于“葫芦三娃有没有挂”话题很是火热,小编也是针对葫芦三娃作*弊开挂的方法以及开挂对应的知识...
玩家最新攻略“甘孜娱乐中心开挂... 家人们!今天小编来为大家解答甘孜娱乐中心透视挂怎么安装这个问题咨询软件客服徽4282891的挂在哪里...
今日重大发现“山城麻将到底是不... 您好:山城麻将这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9752949】很多玩家在这款游戏...
今日重大通报“新青鸟拼三张究竟... 有 亲,根据资深记者爆料新青鸟拼三张是可以开挂的,确实有挂(咨询软件无需...