码迷,mamicode.com
首页 > 数据库 > 详细

MySQL和Oracle行锁比较

时间:2016-08-12 21:53:50      阅读:165      评论:0      收藏:0      [点我收藏+]

标签:innodb   lock   orcale   

有人问,MySQL里Update时条件列没有索引,产生的是表级锁,而Oracle里是行级锁。


下面来对比下MySQL INNODB引擎和Oracle的行锁机制:


INNODB


  1. INNODB表是索引组织的表,主键是聚集索引,非主键索引都包含主键信息。


  2. INNODB默认是行锁。


  3. INNODB行锁是通过给索引项加锁来实现的,即只有通过索引条件检索数据,InnoDB才使用行级锁,否则将使用表锁。

Oracle


  1. 在Oracle的每行数据上,都有一个标志位来表示该行数据是否被锁定。这样就大大减小了行级锁的维护开销,数据行上的锁标志一旦被置位,就表明该行数据被加X锁,Oracle在数据行上没有S锁。


  2. 许多对Oracle不太了解的技术人员可能会以为每一个TX锁代表一条被封锁的数据行,其实不然。TX的本义是Transaction(事务),当一个事 务第一次执行数据更改(Insert、Update、Delete)或使用SELECT… FOR UPDATE语句进行查询时,它即获得一个TX(事务)锁,直至该事务结束(执行COMMIT或ROLLBACK操作)时,该锁才被释放。所以,一个TX 锁,可以对应多个被该事务锁定的数据行。


  3. ORACLE的行级锁 只是数据块头的ITL、数据行头的LB锁标识位,不需要消耗额外的资源。需要注意的是事务并不是被行阻塞,而是被其它的事务阻塞。所以某些数据库就有锁升级机制,而ORACLE没有。ORACLE的行级锁 只是数据块头的ITL、数据行头的LB锁标识位,不需要消耗额外的资源。需要注意的是事务并不是被行阻塞,而是被其它的事务阻塞。所以某些数据库就有锁升级机制,而ORACLE没有。



本文出自 “SQL Server Deep Dive” 博客,请务必保留此出处http://ultrasql.blog.51cto.com/9591438/1837368

MySQL和Oracle行锁比较

标签:innodb   lock   orcale   

原文地址:http://ultrasql.blog.51cto.com/9591438/1837368

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!