[每日一题] 11gOCP 1z0-052 :2013-09-25 Lock ――for update.................................C23
转载请注明出处:http://blog.csdn.net/guoyjoe/article/details/12021587
正确答案:ABE
这道题需要我们了解锁的知识点。
TM锁的模式:
0-None --没有锁 select
1-Null --空锁
2-SS(RS) --行级共享锁(Row Shared,简称RS锁)
通过lock table t10 in row sharemode;命令添加RS锁
3-SX(RX) --行级排他锁(Row exclusive)RX锁
进行DML时,会自动在被更新的表上添加RX锁,可以执行LOCK命令显式的在表上添加RX锁
允许其他事务通过DML语句修改相同表里的其他数据行
允许使用lock table t10 in row exclusive mode;命令对表添加RX锁定;
不允许其他事务对表添加X锁
通过select … from for update命令添加RX锁
4-S --共享锁(Share,简称S锁)
通过lock table t10 in share mode;命令添加该S锁(wait for ITL release)
5-SSX(SRX) --共享行级排他锁(Share Row Exclusive,简称SRX锁)
通过lock table t10 in share rowexclusive mode;命令添加SRX锁
6-X --排他锁(Exclusive,简称X锁)
通过lock table t10 in exclusive mode命令添加X锁
根据题意,我们开起一个会话执行以上的for update的语句会产生一个3号锁(在9i是号锁,10g及以上版本是3号锁)和6号锁。操作如下,观察锁。
1、在125号会话下,执行select语句
gyj@OCM> select sid from v$mystat where rownum=1;
SID
----------
125
gyj@OCM> SELECT ename
2 FROM emp
3 WHERE job='CLERK' FOR UPDATE OF empno;
ENAME
----------
SMITH
ADAMS
JAMES
MILLER
2、查125会话的锁信息
gyj@OCM> select * from v$lock where sid=125; ADDR KADDR SID TY ID1 ID2 LMODE REQUEST CTIME BLOCK
---------------- ---------------- ---------- -- ---------- ---------- ---------- ---------- ---------- ----------
00000000910D8F58 00000000910D8FB0 125 TO 68064 1 3 0 273 0
00000000910D91F8 00000000910D9250 125 AE 100 0 4 0 993 0
00002B18F6AFC2E0 00002B18F6AFC340 125 TM 77522 0 3 0 145 0
000000008FB4E7E0 000000008FB4E858 125 TX 196640 1474 6 0 105 0
发现TM的3号锁,TX的6号锁。
OK,我们对答案一一解析:
答案A正确,会被阻塞。开另一个会话:22号会话,执行如下:
gyj@OCM> select sid from v$mystat where rownum=1;
SID
----------
22
gyj@OCM> LOCK TABLE emp IN SHARE MODE;
被阻塞了,LOCK TABLE emp IN SHARE MODE;会产生4号锁
gyj@OCM> select * from v$lock where sid in(125,22); ADDR KADDR SID TY ID1 ID2 LMODE REQUEST CTIME BLOCK
---------------- ---------------- ---------- -- ---------- ---------- ---------- ---------- ---------- ----------
00000000910D8F58 00000000910D8FB0 125 TO 68064 1 3 0 557 0
00000000910D91F8 00000000910D9250 125 AE 100 0 4 0 1277 0
00000000910DA0F0 00000000910DA148 22 AE 100 0 4 0 304 0
00002B18F6AFD318 00002B18F6AFD378 22 TM 77522 0 0 4 107 0
00002B18F6AFD318 00002B18F6AFD378 125 TM 77522 0 3 0 429 1
000000008FB4E7E0 000000008FB4E858 125 TX 196640 1474 6 0 389 0
答案B正确,会被阻塞。开另一个会话:17号会话,执行如下:
gyj@OCM> select sid from v$mystat where rownum=1;
SID
----------
17
gyj@OCM> LOCK TABLE emp IN EXCLUSIVE MODE;
被阻塞了,LOCK TABLE emp IN EXCLUSIVE MODE;会产生6号锁
gyj@OCM> select * from v$lock where sid in(125,17); ADDR KADDR SID TY ID1 ID2 LMODE REQUEST CTIME BLOCK
---------------- ---------------- ---------- -- ---------- ---------- ---------- ---------- ---------- ----------
00000000910D8F58 00000000910D8FB0 125 TO 68064 1 3 0 726 0
00000000910D91F8 00000000910D9250 125 AE 100 0 4 0 1446 0
00000000910D99F0 00000000910D9A48 17 AE 100 0 4 0 91 0
00002B18F6AFC2E0 00002B18F6AFC340 17 TM 77522 0 0 6 70 0
00002B18F6AFC2E0 00002B18F6AFC340 125 TM 77522 0 3 0 598 1
000000008FB4E7E0 000000008FB4E858 125 TX 196640 1474 6 0 558 0
答案C不正确,不会被阻塞。开一另会话148号会话,操作如下:
gyj@OCM> select sid from v$mystat where rownum=1;
SID
----------
148
gyj@OCM> UPDATE emp SET sal=sal*1.2 WHERE job='MANAGER';
3 rows updated.
没有被阻塞,可以更新,在同一个表中更新不同的行,锁不会有冲突。
gyj@OCM> select * from v$lock where sid in(125,148); ADDR KADDR SID TY ID1 ID2 LMODE REQUEST CTIME BLOCK
---------------- ---------------- ---------- -- ---------- ---------- ---------- ---------- ---------- ----------
00000000910D8F58 00000000910D8FB0 125 TO 68064 1 3 0 1684 0
00000000910D91F8 00000000910D9250 125 AE 100 0 4 0 2404 0
00000000910D92D8 00000000910D9330 148 AE 100 0 4 0 265 0
00002B18F6AFC2E0 00002B18F6AFC340 148 TM 77522 0 3 0 108 0
00002B18F6AFC2E0 00002B18F6AFC340 125 TM 77522 0 3 0 121 0
000000008FB01218 000000008FB01290 148 TX 327685 1488 6 0 65 0
000000008FB4E7E0 000000008FB4E858 125 TX 131082 1475 6 0 121 0
答案D不正确,不会被阻塞。与答案C一样的情况,这里就不再说了。
答案E正确,会被阻塞。开另一会话 143号会话,执行如下
gyj@OCM> select sid from v$mystat where rownum=1;
SID
----------
143
gyj@OCM> SELECT ename FROM emp WHERE job='CLERK' FOR UPDATE OF empno;
被阻塞了,更新同一行,会有行锁的冲突。
gyj@OCM> select * from v$lock where sid in(125,143); ADDR KADDR SID TY ID1 ID2 LMODE REQUEST CTIME BLOCK
---------------- ---------------- ---------- -- ---------- ---------- ---------- ---------- ---------- ----------
00000000910D8F58 00000000910D8FB0 125 TO 68064 1 3 0 2019 0
00000000910D91F8 00000000910D9250 125 AE 100 0 4 0 2739 0
00000000910D98F8 00000000910D9950 143 TX 131082 1475 0 6 82 0
00000000910D9D70 00000000910D9DC8 143 AE 100 0 4 0 114 0
00002B18F6AFD318 00002B18F6AFD378 125 TM 77522 0 3 0 456 0
00002B18F6AFD318 00002B18F6AFD378 143 TM 77522 0 3 0 82 0
000000008FB4E7E0 000000008FB4E858 125 TX 131082 1475 6 0 456 1
锁的机制中有一个非常重要的概念:锁的兼容性,看下面这幅图:
QQ:252803295
技术交流QQ群:
DSI&Core Search Ⅰ 群:127149411(2000人技术群:未满)
DSI&Core Search Ⅱ 群:177089463(1000人技术群:未满)
DSI&Core Search Ⅲ 群:284596437(500人技术群:未满)
DSI&Core Search Ⅳ 群:192136702(500人技术群:未满)
DSI&Core Search Ⅴ 群:285030382(500人闲聊群:未满)
MAIL:dbathink@hotmail.com
BLOG: http://blog.csdn.net/guoyjoe
WEIBO:http://weibo.com/guoyJoe0218
ITPUB: http://www.itpub.net/space-uid-28460966.html
OCM: http://education.oracle.com/education/otn/YGuo.HTM
[每日一题] 11gOCP 1z0-052 :2013-09-25 Lock ――for update.................................C23的更多相关文章
- [每日一题] 11gOCP 1z0-052 :2013-09-1 RMAN-- repair failure........................................A20
转载请注明出处:http://blog.csdn.net/guoyjoe/article/details/10859315 正确答案:D 一.模拟上题的错误: 1.删除4号文件 [oracle@myd ...
- [每日一题] 11gOCP 1z0-053 :2013-10-9 backup with the KEEP option....................................33
转载请注明出处:http://blog.csdn.net/guoyjoe/article/details/12517603 正确答案:AB 在Oracle 11g中,可以使用backup ….keep ...
- [每日一题] 11gOCP 1z0-053 :2013-10-12 RESULT_CACHE在哪个池?.............................44
转载请注明出处:http://blog.csdn.net/guoyjoe/article/details/12657479 正确答案:B Oracle 11g 新特性:Result Cache , ...
- [每日一题] 11gOCP 1z0-052 :2013-08-31 数据库的存储结构....................................................A8
转载请注明出处:http://blog.csdn.net/guoyjoe/article/details/10784599 . 正确答案:A 将逻辑存储与物理存储分开是关系数据库范例的必要部分.关系数 ...
- [每日一题] 11gOCP 1z0-052 :2013-09-19 创建用户...................................................B41
转载请注明出处:http://blog.csdn.net/guoyjoe/article/details/11834661 正确答案:BC 这道题比较简单,我就以答案来解析,如下来自官方文档创建用户的 ...
- [每日一题] 11gOCP 1z0-052 :2013-09-17 DRA--Data Recovery Advisor.............................B31
转载请注明出处:http://blog.csdn.net/guoyjoe/article/details/11818529 正确答案:AD 数据库恢复顾问(DRA)是一个诊断和修复数据库问题的工具.共 ...
- [每日一题] 11gOCP 1z0-052 :2013-09-5 runInstaller oracle of no swap
转载请注明出处:http://blog.csdn.net/guoyjoe/article/details/11186995 正确答案:A 我们先来看下面这张截图,这是我在安装Oracle 11.2.0 ...
- [每日一题] 11gOCP 1z0-053 :2013-10-11 Flashback Data Archive属性.........................43
转载请注明出处:http://blog.csdn.net/guoyjoe/article/details/12656897 正确答案:BD 闪回数据归档请参考:http://blog.csdn.net ...
- [每日一题] 11gOCP 1z0-053 :2013-10-7 the backup of MULT_DATA................................32
转载请注明出处:http://blog.csdn.net/guoyjoe/article/details/12500579 正确答案:D RMAN 的新增功能 对超大型文件应用 Intraf ...
- [每日一题] 11gOCP 1z0-052 :2013-09-2 ADDM(Automatic Database Diagnostic Monitor)...................A28
转载请注明出处:http://blog.csdn.net/guoyjoe/article/details/10951207 正确答案:BC AWR简称Automatic Workload Reposi ...
随机推荐
- WPF最基本的4个引用
Windowsbase Windows基本类库 PresentationCore wpf核心类库 PresentationFramework wpf框架 System.Axml 系统类库
- qt简单界面更新代码(菜鸟级)(部分代码)
qt简单界面更新代码(菜鸟级)(部分代码)self.timers_1=QtCore.QTimer(self)self.timers_1.timeout.connect(self.min_1)self. ...
- mac下识别国产android手机
mac下识别国产android手机困扰了我很久,这几天总算在google帮助下找到了解决方法. 在~/.android/下找到adb_usb.ini,如果不存在则创建.通过“系统信息”查看到插入的an ...
- java时间格式转换
package org.shineway.com; import java.text.ParseException; import java.text.SimpleDateFormat; import ...
- iOS开发CoreAnimation解读之三——几种常用Layer的使用解析
iOS开发CoreAnimation解读之三——几种常用Layer的使用解析 一.CAEmitterLayer 二.CAGradientLayer 三.CAReplicatorLayer 四.CASh ...
- NFinal学习笔记 03—代码生成器
NFinal代码生成器与其他的代码生成器不太一样,只需要运行模块下的WebComplier.aspx即可生成最终的web层代码.包括数据库的操作,Router类, 调试文件等.附上一段代码与大家分享 ...
- Android-现场保护
现场保护 当一个活动进入到了停止的状态,是有可能被系统回收的,我们都学过Activity的生命周期 当活动处于onPause() ,onStop() ,onDestroy() 三种状态时程序可能会被A ...
- J2EE项目开发流程简介
开发流程(一) 提出需求:产品部提出本周期项目的具体需求. 项目计划:项目经理协调开发部.测试部和产品部进行需求协商,产生项目计划. 需求理解:开发部和测试部向产品部提出各自对需求的理解. 产品设计: ...
- (转)在Eclipse中使用JUnit4进行单元测试
原地址:http://blog.csdn.net/andycpp/article/details/1327147
- (原)测试intel的并行计算pafor
转载请注明出处: http://www.cnblogs.com/darkknightzh/p/4988264.html 参考网址: 关于mt19937:http://www.cnblogs.com/e ...