`
solitary
  • 浏览: 71700 次
社区版块
存档分类
最新评论

oracle 行级锁与表级锁

阅读更多
一、行级锁:
(下面这句将给该表的所有行都加上锁)
select * from person for update;

如果该行记录已经被锁定,就不用等待,系统会直接抛错 ora-00054
select * from person  where id = '1'  for update nowait

如果该行记录已经被锁定,更新的时候等待5秒,如果这5秒内,该行记录被解锁,那么返回查询结果,如果5秒内仍未解锁,那么系统会直接抛错 ora-00054
select * from person for update wait 5;

另外,如果使用 select * from person  where id = '1'  for update ,当该行记录已经被锁定时,那么系统将一直等待该行记录被释放后,再加锁。

二、表级锁:

行共享:允许用户进行任何操作,禁止排他锁
lock table person in row share mode;

行排他:允许用户进行任何操作,禁止共享锁
lock table person in row exclusive mode;

共享锁:其他用户只能看,不能修改
lock table person in share mode;

共享行排他:比共享锁有更多限制
lock table person in share row exclusive mode;

排他锁:其他用户只能看,不能修改,不能加其他锁
lock table person in exclusive mode;


对于通过lock table命令主动添加的锁定来说,如果要释放它们,只需要发出rollback命令即可。
3
1
分享到:
评论
4 楼 surgar 2014-07-15  
[url][/url]
3 楼 surgar 2014-07-15  
[img][/
|
]  [b][/b]
引用
2 楼 solitary 2012-03-01  
自己顶一个
1 楼 crystal2012 2012-02-07  
很好很强大

相关推荐

    MySQL中的行级锁、表级锁、页级锁

    在DBMS中,可以按照锁的粒度把数据库锁分为行级锁(INNODB引擎)、表级锁(MYISAM引擎)和页级锁(BDB引擎 )。 一、行级锁 行级锁是Mysql中锁定粒度最细的一种锁,表示只针对当前操作的行进行加锁。行级锁能大大减少...

    oracle常见的锁查询和处理

    表级锁(TM锁) 锁定相关视图 v$transaction v$lock 5 v$enqueue_lock v$session 检测并解决冲突 常见的锁查询和处理 当前系统中存在的锁争用: 引发争用的session信息: 引发争用的sql语句: 引发争用的数据对象 ...

    Oracle五种表级排他锁的总结和归纳

    Oracle五种表级排他锁的总结和归纳行级排他锁 (Row Exclusive Table Lock,RX)

    oracle锁机制探讨

    在Oracle数据库中,DML锁主要包括TM锁和TX锁,其中TM锁称为表级锁(用来保证表的结构不被用户修改),TX锁称为事务锁或行级锁。当Oracle执行DML语句时,系统自动在所要操作的表上申请TM类型的锁。当TM锁获得后,系统...

    MySQL中的行级锁定示例详解

    锁是在执行多线程时用于强行限定资源访问的同步机制,数据库锁根据锁的粒度可分为行级锁,表级锁和页级锁 行级锁 行级锁是mysql中粒度最细的一种锁机制,表示只对当前所操作的行进行加锁,行级锁发生冲突的概率很...

    ORACLE锁深入分析

    在Oracle数据库中,DML锁主要包括TM锁和TX锁,其中TM锁称为表级锁,TX锁称为事务锁或行级锁。? 当Oracle执行DML语句时,系统自动在所要操作的表上申请TM类型的锁。当TM锁获得后,系统再自动申请TX类型的锁,并将实际...

    oracle中锁的级别和锁表语句

    文章目录锁模式值列表锁表语句例子wait 和 nowait锁模式row share(share update) 2级锁row exclusive 3级锁share 4级锁share row exclusive 5级锁exclusive 6级锁各个锁的例子其他 锁模式值列表 值为0-6。其实常见的...

    mysql和oracle的区别小结(功能性能、选择、使用它们时的sql等对比)

    虽然InnoDB引擎的表可以用行级锁,但这个行级锁的机制依赖于表的索引,如果表没有索引,或者sql语句没有使用索引,那么仍然使用表级锁。 oracle: oracle使用行级锁,对资源锁定的粒度要小很多,只是锁定sql需要的...

    快速查出Oracle数据库中锁等待的方法

    这些锁定中有”只读锁”、”排它锁”,”共享排它锁”等多种类型,而且每种类型又有”行级锁”(一次锁住一条记录),”页级锁”(一次锁住一页,即数据库中存储记录的最小可分配单元),”表级锁”(锁住整个表)。...

    详解mysql 中的锁结构

     行级锁和表级锁本来就有许多不同之处,另外,事务的引入也带来了一些新问题。 InnoDB的行锁模式及加锁方法 InnoDB实现了以下两种类型的行锁。 共享锁(s):允许一个事务去读一行,阻止其他事务获

    mysql和oracle的区别(功能性能、选择、使用它们时的sql等对比)

    虽然InnoDB引擎的表可以用行级锁,但这个行级锁的机制依赖于表的索引,如果表没有索引,或者sql语句没有使用索引,那么仍然使用表级锁。 oracle: oracle使用行级锁,对资源锁定的粒度要小很多,只是锁定sql需要的...

    oracle SQL命令大全

    (删除表中记录时释放表空间) DML 语句: 表级共享锁: 对于操作一张表中的不同记录时,互不影响 行级排它锁:对于一行记录,oracle 会只允许只有一个用户对它在同一时间进行修改操作 wait() 等到行级锁被释放,...

    ORACLE9i_优化设计与系统调整

    §1.1.2 表空间与数据文件 24 §1.1.3 Oracle实例(Instance) 24 §1.2 Oracle文件 26 §1.2.1 数据文件 26 §1.2.2 控制文件 26 §1.2.3 重做日志文件 26 §1.2.4 其它支持文件 26 §1.3 数据块、区间和段 28 §...

    oracle学习文档 笔记 全面 深刻 详细 通俗易懂 doc word格式 清晰 连接字符串

    从就业与择业的角度来讲,计算机相关专业的大学生从事oracle方面的技术是职业发展中的最佳选择。 其一、就业面广:全球前100强企业99家都在使用ORACLE相关技术,中国政府机构,大中型企事业单位都能有ORACLE技术的...

    Oracle数据库、SQL

    8.4行级信息和组级信息 16 九、 group by子句 17 9.1语法和执行顺序 17 9.2分组过程 17 9.3常见错误 17 9.4多列分组 17 十、 having子句 18 10.1语法和执行顺序 18 10.2执行过程 18 10.3 where和having区别 18 十一...

    最全的oracle常用命令大全.txt

    查看当前用户的系统权限和表级权限 SQL>select * from user_sys_privs; SQL>select * from user_tab_privs; 2、表 查看用户下所有的表 SQL>select * from user_tables; 查看名称包含log字符的表 SQL>...

    oracle数据库经典题目

    行级共享锁 D. 死锁 26. 想在另一个模式中创建表,用户最少应该具有什么系统权限?( B ) A.CREATE TABLE B. CREATE ANY TABLE C. RESOURCE D. DBA 27. 如果要启用所有角色,则应该使用哪一个命令?( B ) A....

    orcale常用命令

    查看当前用户的系统权限和表级权限 SQL>select * from user_sys_privs; SQL>select * from user_tab_privs; 2、表 查看用户下所有的表 SQL>select * from user_tables; 查看名称包含log字符的表 SQL>...

    Oracle从入门到精通

    1.5、SQLPLUS 与 SQL 的关系................................ 1、SQLPLUS命令的功能: ................................... 2、查询 SQLPLUS 命令...................................... 3、SQLPLUSW 在 WINDOWS ...

Global site tag (gtag.js) - Google Analytics