oracle记录锁怎么看 oracle怎样查看锁表

怎么查看数据库锁表?怎么知道数据库表已经锁表oracle记录锁怎么看了
先回答你的问题:
select *from v$locked_object;
可以获得被锁的对象的object_id及产生锁的会话sid 。
通过查询结果中的object_idoracle记录锁怎么看,可以查询到具体被锁的对象
再给你看看oracle记录锁怎么看我查到的一些关于锁的资料:
锁有以下几种模式:
0:none
1:null 空
2:Row-S 行共享(RS):共享表锁
3:Row-X 行专用(RX):用于行的修改
4:Share 共享锁(S):阻止其他DML操作
5:S/Row-X 共享行专用(SRX):阻止其他事务操作
6:exclusive 专用(X):独立访问使用
数字越大锁级别越高, 影响的操作越多 。
一般的查询语句如select ... from ... ;是小于2的锁, 有时会在v$locked_object出现 。
select ... from ... for update; 是2的锁 。
当对话使用for update子串打开一个游标时,
所有返回集中的数据行都将处于行级(Row-X)独占式锁定,
其他对象只能查询这些数据行 , 不能进行update、delete或select...for update操作 。
insert / update / delete ... ; 是3的锁 。
没有mit之前插入同样的一条记录会没有反应,
因为后一个3的锁会一直等待上一个3的锁, 我们必须释放掉上一个才能继续工作 。
创建索引的时候也会产生3,4级别的锁 。
locked_mode为2,3,4不影响DML(insert,delete,update,select)操作,
但DDL(alter,drop等)操作会提示ora-00054错误 。
有主外键约束时 update / delete ... ; 可能会产生4,5的锁 。
DDL语句时是6的锁 。
以DBA角色, 查看当前数据库里锁的情况可以用如下SQL语句:
select object_id,session_id,locked_mode from v$locked_object;
select t2.username,t2.sid,t2.serial#,t2.logon_time
from v$locked_object t1,v$session t2
where t1.session_id=t2.sid order by t2.logon_time;
如果有长期出现的一列,可能是没有释放的锁 。
我们可以用下面SQL语句杀掉长期没有释放非正常的锁:
alter system kill session 'sid,serial#';
如果出现了锁的问题, 某个DML操作可能等待很久没有反应 。
当你采用的是直接连接数据库的方式,
也不要用OS系统命令 $kill process_num 或者 $kill -9 process_num来终止用户连接,
因为一个用户进程可能产生一个以上的锁, 杀OS进程并不能彻底清除锁的问题 。
记得在数据库级别用alter system kill session 'sid,serial#';杀掉不正常的锁 。
这里还讲了一些:
......
查看oracle是否锁表
Oracle数据库操作中,我们有时会用到锁表查询以及解锁和kill进程等操作,那么这些操作是怎么实现的呢oracle记录锁怎么看?本文我们主要就介绍一下这部分内容 。
(1)锁表查询的代码有以下的形式:
select count(*) from v$locked_object;
select * from v$locked_object;
(2)查看哪个表被锁
select b.owner,b.object_name,a.session_id,a.locked_mode from v$locked_object a,dba_objects b where b.object_id = a.object_id;
(3)查看是哪个session引起的
select b.username,b.sid,b.serial#,logon_time from v$locked_object a,v$session b where a.session_id = b.sid order by b.logon_time;
(4)杀掉对应进程
执行命令:alter system kill session'1025,41';
其中1025为sid,41为serial#.
怎么查看 sql server 数据库有没有锁表
--查看被锁表: select request_session_id spid,OBJECT_NAME(resource_associated_entity_id) tableName from sys.dm_tran_locks where resource_type='OBJECT' --spid 锁表进程 --tableName 被锁表名 -- 解锁: declare @spid int Set @spid = 57 --锁表进程 declare @sql varchar(1000) set @sql='kill ' cast(@spid as varchar) exec(@sql)
MYSQL数据库怎么查看 哪些表被锁了
用navicate工具可以轻松查看
里面lock的就是被锁的
查询oracle 数据库里有哪些表锁死
查锁 ,
SELECT /*rule */ s.username,
decode(l.type,'TM','TABLE LOCK',
'TX','ROW LOCK',
NULL) LOCK_LEVEL,
o.owner,o.object_name,o.object_type,
s.sid,s.serial#,s.terminal,s.machine,s.program,s.osuser
FROM v$session s,v$lock l,dba_objects o
WHERE l.sid = s.sid
AND l.id1 = o.object_id( )
AND s.username is NOT NULL
杀锁
alter system kill session '25,7357'
如何查询mysql数据库表是否被锁 csdn
show OPEN TABLES where In_use0;
如何查看mysql中表的锁定情况
1 show processlist;
【oracle记录锁怎么看 oracle怎样查看锁表】 SHOW PROCESSLIST显示哪些线程正在运行 。您也可以使用mysqladmin processlist语句得到此信息 。如果您有SUPER权限,您可以看到所有线程 。否则,您只能看到您自己的线程(也就是,与您正在使用的MySQL账户相关的线程) 。如果有线程在update或者insert 某个表 , 此时进程的status为updating 或者 sending data 。
如果您得到“too many connections”错误信息,并且想要了解正在发生的情况,本语句是非常有用的 。MySQL保留一个额外的连接,让拥有SUPER权限的账户使用 , 以确保管理员能够随时连接和检查系统(假设您没有把此权限给予所有的用户) 。
Status
含义
Checking table
正在检查数据表(这是自动的) 。
Closing tables
正在将表中修改的数据刷新到磁盘中 , 同时正在关闭已经用完的表 。这是一个很快的操作,如果不是这样的话 , 就应该确认磁盘空间是否已经满了或者磁盘是否正处于重负中 。
Connect Out
复制从服务器正在连接主服务器 。
Copying to tmp table on disk
由于临时结果集大于tmp_table_size,正在将临时表从内存存储转为磁盘存储以此节省内存 。
Creating tmp table
正在创建临时表以存放部分查询结果 。
deleting from main table
服务器正在执行多表删除中的第一部分,刚删除第一个表 。
deleting from reference tables
服务器正在执行多表删除中的第二部分,正在删除其他表的记录 。
Flushing tables
正在执行FLUSH TABLES,等待其他线程关闭数据表 。
Killed
发送了一个kill请求给某线程,那么这个线程将会检查kill标志位,同时会放弃下一个kill请求 。MySQL会在每次的主循环中检查kill标志位,不过有些情况下该线程可能会过一小段才能死掉 。如果该线程程被其他线程锁住了,那么kill请求会在锁释放时马上生效 。
Locked
被其他查询锁住了 。
Sending data
正在处理SELECT查询的记录,同时正在把结果发送给客户端 。
Sorting for group
正在为GROUP BY做排序 。
Sorting for order
正在为ORDER BY做排序 。
Opening tables
这个过程应该会很快,除非受到其他因素的干扰 。例如,在执ALTER TABLE或LOCK TABLE语句行完以前 , 数据表无法被其他线程打开 。正尝试打开一个表 。
Removing duplicates
正在执行一个SELECT DISTINCT方式的查询 , 但是MySQL无法在前一个阶段优化掉那些重复的记录 。因此,MySQL需要再次去掉重复的记录,然后再把结果发送给客户端 。
Reopen table
获得了对一个表的锁,但是必须在表结构修改之后才能获得这个锁 。已经释放锁 , 关闭数据表,正尝试重新打开数据表 。
Repair by sorting
修复指令正在排序以创建索引 。
Repair with keycache
修复指令正在利用索引缓存一个一个地创建新索引 。它会比Repair by ......
如何查看SQL数据有没有锁表
后续版本的 Microsoft SQL Server 将删除该功能 。请避免在新的开发工鼎中使用该功能,并着手修改当前还在使用该功能的应用程序 。若要获取有关 SQL Server 数据库引擎中的锁的信息 , 请使用 sys.dm_tran_locks 动态管理视图 。
USE master;
GO
EXEC sp_lock 53;
GO
查看Oracle中是否有锁表的sql
查锁,
SELECT /*rule */ s.username,
decode(l.type,'TM','TABLE LOCK',
'TX','ROW LOCK',
NULL) LOCK_LEVEL,
o.owner,o.object_name,o.object_type,
s.sid,s.serial#,s.terminal,s.machine,s.program,s.osuser
FROM v$session s,v$lock l,dba_objects o
WHERE l.sid = s.sid
AND l.id1 = o.object_id( )
AND s.username is NOT NULL
杀锁
alter system kill session '25,7357'
如何查询mysql中是否表被锁
show OPEN TABLES where In_use0;
show global status like 'table_locks%';
Oracle如何锁定记录分类:电脑/网络软件其他软件
问题描述:
在ORACLE中...比如我在查询一条记录时,怎么保证这条记录不被别人删除或修改操作 , 也就是锁定记录 。请问有这种语句吗??
解析:
select 'X' from table where ... for update;
oracle记录被另一个用户锁住怎么办数据库是一个多用户使用的共享资源 。当多个用户并发地存取数据时,在数据库中就会产生多个事务同时存取同一数据的情况 。若对并发操作不加控制就可能会读取和存储不正确的数据 , 破坏数据库的一致性 。
加锁是实现数据库并发控制的一个非常重要的技术 。当事务在对某个数据对象进行操作前,先向系统发出请求,对其加锁 。加锁后事务就对该数据对象有了一定的控制,在该事务释放锁之前,其他的事务不能对此数据对象进行更新操作 。
在数据库中有两种基本的锁类型:排它锁(Exclusive Locks,即X锁)和共享锁(Share Locks,即S锁) 。当数据对象被加上排它锁时,其他的事务不能对它读取和修改 。加了共享锁的数据对象可以被其他事务读?。?但不能修改 。数据库利用这两种基本的锁类型来对数据库的事务进行并发控制 。
根据保护的对象不同 , Oracle数据库锁可以分为以下几大类:
DML锁(data locks , 数据锁),用于保护数据的完整性;
DDL锁(dictionary locks , 字典锁),用于保护数据库对象的结构,如表、索引等的结构定义;
内部锁和闩(internal locks and latches) , 保护数据库的内部结构 , 应用于SGA;
在我们实际应用开发中涉及较多的是DML锁,其他两种的话DBA会更加关心点;
DML锁的目的在于保证并发情况下的数据完整性,主要包括TM锁和TX锁,其中TM锁称为表级锁,TX锁称为事务锁或行级锁 。
当Oracle执行DML语句时,系统自动在所要操作的表上申请TM类型的锁 。当TM锁获得后,系统再自动申请TX类型的锁,并将实际锁定的数据行的锁标志位进行置位 。这样在事务加锁前检查TX锁相容性时就不用再逐行检查锁标志,而只需检查TM锁模式的相容性即可,大大提高了系统的效率 。TM锁包括了SS、SX、S、X等多种模式,在数据库中用0-6来表示 。不同的SQL操作产生不同类型的TM锁 。如下图所示:
值锁模式锁描述SQL
0NONE
1NULL空SELECT
2SS(ROW-S)行级共享锁
其他对象只能查询这些数据行SELECT FOR UPDATE、LOCK FOR UPDATE、
LOCK ROW SHARE
3SX(ROW-X)行级排它锁
在提交前不允许做DML操作INSERT、UPDATE、DELETE、
LOCK ROW SHARE
4S(SHARE)共享锁CREATE INDEX、LOCK SHARE
5SSX(S/ROW-X)共享行级排它锁LOCK SHARE ROW EXCLUSIVE
6X(eXclusive)排它锁ALTER TABLE、DROP TABLE、DROP INDEX、
TRUNCATE TABLE、LOCK EXCLUSIVE
在数据行上只有X锁(排他锁) 。在 Oracle数据库中 , 当一个事务首次发起一个DML语句时就获得一个TX锁 , 该锁保持到事务被提交或回滚 。当两个或多个会话在表的同一条记录上执行 DML语句时,第一个会话在该条记录上加锁 , 其他的会话处于等待状态 。当第一个会话提交后,TX锁被释放,其他会话才可以加锁 。
在大概了解oracle的锁机制之后,我们来解决几个基本的问题:
1.UPDATE/DELETE操作会将RS锁定,直至操作被COMMIT或者ROLLBACK;
若操作未COMMIT之前其他session对同样的RS做变更操作,则操作会被hold,直至前session的UPDATE/DELETE操作被COMMIT;
2.session内外SELECT的RS范围
前提:INSERT、UPDATE操作未COMMIT之前进行SELECT;
若在同一session内 , SELECT出来的RS会包括之前INSERT、UPDATE影响的记录;
若不在同一session内 , SELECT出来的RS不会包括未被COMMIT的记录;
3.SELECT.... FOR UPDATE [OF cols] [NOWAIT/WAIT] [SKIP LOCKED]
OF cols:只锁定指定字段所在表的RS,而没有指定的表则不会锁定,只会在多表联合查询时出现;
NOWAIT:语句不会hold,而是直接返回错误ORA-00054: resource busy and acquire with NOWAIT specified;
WAIT N:语句被hold N秒,之后返回错误ORA-30006: resource busy; acquire with WAIT timeout expired;
SKIP LOCKED:不提示错误,而是直接返回no rows selected;
以上几个选项可以联合使用的 , 比较推荐的有:
SELECT.... FOR UPDATE NOWAIT:对同一RS执行该SQL时,直接返回错误;
SELECT.... FOR UPDATE NOWAIT SKIP LOCKED:对同一RS执行该SQL时 , 直接返回空行;
PS:当RS被LOCK住之后,只对同样请求LOCK的语句有效 , 对无需LOCK的SELECT语句并没有任何影响;
Oracle中的锁这些是基?。?必须掌握:锁定的概念:锁定是数据库用来控制共享资源并发布访问的机制 。在多用户环境下,多个用户可同时访问相同的数据 。Oracle 提供锁以确保在多用户环境下数据的完整性和一致性 。在提交或回滚事务之前,Oracle 会锁定正被修改的数据 。在用户完成或回滚事务之后,锁会自动释放 。只有在提交或回滚事物之后,其他用户才可以更新这些数据 。锁的两种级别为:行级锁和表级锁 。行级锁主要用于特定的行 , 表级锁主要用于整个表 , 下面我就行级锁和表级锁来个说明:行级锁行级锁只对用户正在访问的行进行锁定 。如果该用户正在修改某行,那么其他用户就可以更新同一表中该行之外的数据 。例如:如果用户1正在更新Jobs 表中的第一行,则用户2可以同时修改该表中的第二行 。也就是说除了该表中的第一行,其他用户可以修改任意行 , 但是第一行的数据其他用户只能select 。行级锁是一种排他锁,防止其他事务修改此行,但是不会阻止读取此行的操作 。在使用INSERT、UPDATE、DELETE 和SELECT…FOR UPDATE 等 语句时,Oracle 会自动应用行级锁锁定 。SELECT...FOR UPDATE 语句允许用户每次选择多行记录进行更新,这些记录会被锁定,且只能由发起查询的用户进行编辑 。只有在回滚或提交事务之后,锁定才会释放 , 其他用户才可以编辑这些记录 。SELECT...FOR UPDATE 语句的语法如下: SELECT ... FOR UPDATE [OF column_list][WAIT n|NOWAIT];其中:OF 子句用于指定即将更新的列,即锁定行上的特定列 。WAIT 子句指定等待其他用户释放锁的秒数,防止无限期的等待 。“使用FOR UPDATE WAIT”子句的优点如下:⒈防止无限期地等待被锁定的行;⒉允许应用程序中对锁的等待时间进行更多的控制 。⒊对于交互式应用程序非常有用 , 因为这些用户不能等待不确定举例:比如一个用户在SQL PLUS下输入这条语句:SQLSELECT * FROM order_master WHERE vencode='V002' FOR UPDATE;此时再开启一个SQL PLUS,以相同的用户登陆,执行下面的命令 。SQL SELECT * FROM order_master WHERE vencode='V02' FOR UPDATE WAIT 5;由于要更新的行已经被锁定,上述命令在等待5秒钟之后返回,并给出如下的错误信息:ERROR 位于第1行;ORA-30006;资源已被占用;执行操作时出现WAIT超时 。PS:再开启的SQL PLUS 是以相同用户登陆的,用其他用户登陆更是不可能 。表级锁表级锁被锁定的表,暂时放在内存中,不提交不进去数据库 , 也就是说,多个用户在同一时间 , 同时修改同一个表的同一行时,同时点提交,但是还是按随机的先后被提交进数据库,而不是同时被提交,而是先随机存储后,被再次提交的覆盖 。表级锁将保护表数据,在事务处理过程中 , 表级锁会限制对整个表的访问 。可以使用LOCK TABLE 语句显示地锁定表 。表级锁用来限制对表执行添加、更新和删除等修改操作 。锁定表的语法如下:LOCK TABLE table_name IN lock_mode MODE [NOWAIT];其中:lock_mode 是锁定的模式 。NOWAIT 关键字用于防止无限期的等待其他用户释放锁 。表级锁的模式包括以下内容:行共享 (ROW SHARE, RS): 允许其他用户访问和锁定该表,但是禁止排他锁定整个表 。行共享锁锁定后 , 在同一时刻,不同用户可以对同一个表中的被行共享锁锁定后的该行,具备增、删、改、查的功能 。行排他(ROW EXCLUSIVE, RX):与行共享模式相同 , 同时禁止其他用户在此表上使用共享锁 。使用SELECT...FOR UPDATE 语句会在表上自动应用排他锁 。被行排他后,其他用户不能同时修改该行,但是可以插入行,可以查询该行,其他用户也不能再在该表上对此行进行排他 。共享(SHARE, S):共享锁将锁定表,仅允许其他用户查询表中的行,但不允许插入、更新或删除行 。多个用户可以同时在同一个表中放置共享锁,即允许资源共享,因此得名“共享锁” 。例如,如果用户每天都需要在结帐时更新日销售表,则可以在更改该表时使用共享锁以确保数据的一致性 。也就是说该表只能查,其他用户想修改表中行的数据 , 只需要对该表进行共享锁 。共享行排他(SHARE ROW EXCLUSIVE , SPX):执行比共享表更多的限制 。防止其他事务在表上应用共享锁、共享行排他锁以及排他锁 。共享行排他是除了该行以外的其他行也不能增、删、改 。只能在此表中加低级表 。要是想在该表中更改其他行的数据,就只有其他用户对该行进行共享行排他锁 , 也仅仅只能修改被这个用户锁定的行,而其他的行也修改不了 。排他(EXCLUSIVE , E):对表执行最大限制 。除了允许其他用户查询该表的记录 , 排他锁防止其他事务对表做任何更改或在表上应用任何类型的锁 。这个锁应该叫锁中之王 , 他锁住了的话,其他用户就只有查询的功能了,就别想在该表中干别的事了 。BTW:在能加很多锁的表中,如果第一个用户对该表锁定时,没有使用“NOWAIT”语句 , 是需要第一个用户对该表COMMIT或ROLLBACK 命令释放锁定后,其他用户才能对该表进行锁定 。如果其他用户违反了该条,就会无期限的等待 。。。。SQL LOCK TABLE order_mater IN SHARE MODE;而使用下面的语句就可以很少的预防这种情况的存在:SQL LOCK TBALE order_mater IN SHARE MODE NOWAIT;这是些扩展的内容,供大家参考
1 引言—数据库锁的基本概念为了确保并发用户在存取同一数据库对象时的正确性(即无丢失修改、可重复读、不读“脏”数据),数据库中引入了锁机制 。基本的锁类型有两种:排它锁(Exclusive locks记为X锁)和共享锁(Share locks记为S锁) 。排它锁:若事务T对数据D加X锁 , 则其它任何事务都不能再对D加任何类型的锁 , 直至T释放D上的X锁;一般要求在修改数据前要向该数据加排它锁,所以排它锁又称为写锁 。共享锁:若事务T对数据D加S锁 , 则其它事务只能对D加S锁,而不能加X锁 , 直至T释放D上的S锁;一般要求在读取数据前要向该数据加共享锁,所以共享锁又称为读锁 。2 Oracle 多粒度封锁机制介绍根据保护对象的不同,Oracle数据库锁可以分为以下几大类:(1) DML lock(data locks,数据锁):用于保护数据的完整性;(2) DDL lock(dictionary locks,字典锁):用于保护数据库对象的结构(例如表、视图、索引的结构定义);(3) internal locks 和l a t c h es(内部锁与闩):保护内部数据库结构;(4) distributed locks(分布式锁):用于OPS(并行服务器)中;(5) PCM locks(并行高速缓存管理锁):用于OPS(并行服务器)中 。本文主要讨论DML(也可称为data locks,数据锁)锁 。从封锁粒度(封锁对象的大?。┑慕嵌瓤?,Oracle DML锁共有两个层次 , 即行级锁和表级锁 。2.1 Oracle的TX锁(行级锁、事务锁)许多对Oracle不太了解的技术人员可能会以为每一个TX锁代表一条被封锁的数据行,其实不然 。TX的本义是Transaction(事务),当一个事务第一次执行数据更改(Insert、Update、Delete)或使用SELECT… FOR UPDATE语句进行查询时,它即获得一个TX(事务)锁 , 直至该事务结束(执行COMMIT或ROLLBACK操作)时,该锁才被释放 。所以 , 一个TX锁 , 可以对应多个被该事务锁定的数据行 。在Oracle的每行数据上,都有一个标志位来表示该行数据是否被锁定 。Oracle不象其它一些DBMS(数据库管理系统)那样,建立一个链表来维护每一行被加锁的数据,这样就大大减小了行级锁的维护开销,也在很大程度上避免了其它数据库系统使用行级封锁时经常发生的锁数量不够的情况 。数据行上的锁标志一旦被置位,就表明该行数据被加X锁,Oracle在数据行上没有S锁 。
2.2 TM锁(表级锁) 2.2.1 意向锁的引出表是由行组成的 , 当我们向某个表加锁时,一方面需要检查该锁的申请是否与原有的表级锁相容;另一方面,还要检查该锁是否与表中的每一行上的锁相容 。比如一个事务要在一个表上加S锁,如果表中的一行已被另外的事务加了X锁 , 那么该锁的申请也应被阻塞 。如果表中的数据很多,逐行检查锁标志的开销将很大,系统的性能将会受到影响 。为了解决这个问题 , 可以在表级引入新的锁类型来表示其所属行的加锁情况,这就引出了“意向锁”的概念 。意向锁的含义是如果对一个结点加意向锁,则说明该结点的下层结点正在被加锁;对任一结点加锁时,必须先对它的上层结点加意向锁 。如:对表中的任一行加锁时 , 必须先对它所在的表加意向锁,然后再对该行加锁 。这样一来,事务对表加锁时,就不再需要检查表中每行记录的锁标志位了,系统效率得以大大提高 。2.2.2 意向锁的类型由两种基本的锁类型(S锁、X锁),可以自然地派生出两种意向锁:意向共享锁(Intent Share Lock,简称IS锁):如果要对一个数据库对象加S锁,首先要对其上级结点加IS锁,表示它的后裔结点拟(意向)加S锁;意向排它锁(Intent Exclusive Lock,简称IX锁):如果要对一个数据库对象加X锁,首先要对其上级结点加IX锁,表示它的后裔结点拟(意向)加X锁 。另外,基本的锁类型(S、X)与意向锁类型(IS、IX)之间还可以组合出新的锁类型,理论上可以组合出4种,即:S IS,S IX,X IS,X IX,但稍加分析不难看出 , 实际上只有S IX有新的意义,其它三种组合都没有使锁的强度得到提高(即:S IS=S , X IS=X,X IX=X , 这里的“=”指锁的强度相同) 。所谓锁的强度是指对其它锁的排斥程度 。这样我们又可以引入一种新的锁的类型 。共享意向排它锁(Shared Intent Exclusive Lock,简称SIX锁) :如果对一个数据库对象加SIX锁,表示对它加S锁,再加IX锁,即SIX=S IX 。例如:事务对某个表加SIX锁,则表示该事务要读整个表(所以要对该表加S锁),同时会更新个别行(所以要对该表加IX锁) 。这样数据库对象上所加的锁类型就可能有5种:即S、X、IS、IX、SIX 。具有意向锁的多粒度封锁方法中任意事务T要对一个数据库对象加锁,必须先对它的上层结点加意向锁 。申请封锁时应按自上而下的次序进行;释放封锁时则应按自下而上的次序进行;具有意向锁的多粒度封锁方法提高了系统的并发度,减少了加锁和解锁的开销 。2.2.3 Oracle的TM锁(表级锁)Oracle的DML锁(数据锁)正是采用了上面提到的多粒度封锁方法 , 其行级锁虽然只有一种(即X锁),但其TM锁(表级锁)类型共有5种,分别称为共享锁(S锁)、排它锁(X锁)、行级共享锁(RS锁)、行级排它锁(RX锁)、共享行级排它锁(SRX锁) , 与上面提到的S、X、IS、IX、SIX相对应 。需要注意的是,由于Oracle在行级只提供X锁,所以与RS锁(通过SELECT … FOR UPDATE语句获得)对应的行级锁也是X锁(但是该行数据实际上还没有被修改) , 这与理论上的IS锁是有区别的 。下表为Oracle数据库TM锁的相容矩阵(Y=Yes,表示相容的请求; N=No,表示不相容的请求;-表示没有加锁请求):
T2
T1 S X RS RX SRX -
----------------------------------------------------
S Y N Y N N Y
X N N N N N Y
RS Y N Y Y Y Y
RX N N Y Y N Y
SRX N N Y N N Y
- Y Y Y Y Y Y
表一:Oracle数据库TM锁的相容矩阵一方面,当Oracle执行SELECT…FOR UPDATE、INSERT、UPDATE、DELETE等DML语句时,系统自动在所要操作的表上申请表级RS锁(SELECT…FOR UPDATE)或RX锁(INSERT、UPDATE、DELETE) , 当表级锁获得后,系统再自动申请TX锁,并将实际锁定的数据行的锁标志位置位(指向该TX锁);另一方面,程序或操作人员也可以通过LOCK TABLE语句来指定获得某种类型的TM锁 。下表总结了Oracle中各SQL语句产生TM锁的情况: SQL语句表锁模式允许的锁模式
-------------------------------------------------------------------------------------------------
Select * from table_name……无RS、RX、S、SRX、X
Insert into table_name……RXRS、RX
Update table_name……RXRS、RX
Delete from table_name……RXRS、RX
Select * from table_name for updateRSRS、RX、S、SRX
lock table table_name in row share modeRSRS、RX、S、SRX
lock table table_name in row exclusive modeRXRS、RX
lock table table_name in share modeSRS、S
lock table table_name in share row exclusive mode SRXRS
lock table table_name in exclusive modeX无
oracle记录锁怎么看的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于oracle怎样查看锁表、oracle记录锁怎么看的信息别忘了在本站进行查找喔 。

    推荐阅读