[原创]MySQL存储引擎InnoDB各SQL语句的锁定设置_MySQL, Oracle及数据库讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  MySQL, Oracle及数据库讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 2819 | 回复: 0   主题: [原创]MySQL存储引擎InnoDB各SQL语句的锁定设置        下一篇 
tngou
注册用户
等级:中校
经验:2433
发帖:192
精华:15
注册:2014-4-28
状态:离线
发送短消息息给tngou 加好友    发送短消息息给tngou 发消息
发表于: IP:您无权察看 2014-7-9 18:56:08 | [全部帖] [楼主帖] 楼主   主页

    1、SELECT ... FROM ...: 这是一个 consistent read,不以锁定方式读取数据库的快照,除非事务的隔离级被设置为SERIALIZABLE,在这种情况下将在它所读取的记录索引上设置共享的 next-key locks。

    2、 SELECT ... FROM ... LOCK IN SHARE MODE: 在所读取的所有记录索引上设置同享的锁定。

    3、SELECT ... FROM ... FOR UPDATE: 在所读取的所胡记录索引上设置独占地(exclusive)锁定。

    4、INSERT INTO ... VALUES (...): 在插入的记录行上设置一个独占地锁定;注意这个锁定并不是一个 next-key lock ,并不会阻止其它用户在所插入行之前的间隙(gap)中插入新记录。如果产生一个重复键值错误, 在重复索引记录上设置一个共享的锁定。

    5、INSERT INTO T SELECT ... FROM S WHERE ...在已插入到表T中的每个记录上设置一个独占的(无 next-key)锁定。以一个 consistent read 搜索表S,但是如果 MySQL 打开了日志开关将在表S上设置一个共享的锁定。 在从备份中进行前滚(roll-forward)修复时,每个 SQL 语句必须严格按照原先所执行的顺序运行,所以 InnoDB 不得不设置锁定。

    6、CREATE TABLE ... SELECT ...与上项相似,以 consistent read 或锁定方式完成SELECT。

    7、REPLACE如果没有一个 unique key 冲突,它的执行与 insert 一致。否则将在它所要更新的记录上设置一个独占的锁定。

    8、UPDATE ... SET ... WHERE ...: 在搜索时所遭遇到的记录上设置一个独占的锁定。

    9、 DELETE FROM ... WHERE ...: 在搜索时所遭遇到的每一个记录上设置一个独占的锁定。

    10、如果一个表上有FOREIGN KEY约束,所有需要检查约束条件的 insert, update, 或 delete 将在它所要检查约束的记录上设记录共享级的锁定。同样在约束失败时,InnoDB 也设置这个锁定。

    11、LOCK TABLES ...: 设置表锁定。在 MySQL 的代码层(layer of code)设置这些锁定。InnoDB 的自动死锁检测无法检测出有关下列情形的表锁定:查看下面的一个章节。同时查看第 14 章节 'InnoDB 限制与不足' 有关下列内容: 自从 MySQL 提供行锁以来,将有可能发生当其他用户设置了行级锁定时你又对该表设置了锁定。But that does not put transaction integerity into danger.

    12、在 早期 版本以前,SHOW TABLE STATUS应用于一个自增表时将在自增列的最大记录索引上设置一个独占的行级锁定。 这就意味着SHOW TABLE STATUS可能会引起一个事务的死锁,这可能是我们所意想不到的。从 3.23.50 开始,在读取自增列值时将不再设置任何锁定,除非在某些情况下,比如在数据库启动后没有任何记录。

    13、如果在一个表中定义了一个AUTO_INCREMENT列,InnoDB 

在初始化自增计数器时将在与自增列最后一个记录相对应的索引上设置一个独占的锁定。在访问自增计数器时, InnoDB 

将设置一个特殊的表锁定模式AUTO-INC,这个锁定只持续到该 SQL 语句的结束而不是整个事务的结束。

该贴被tngou编辑于2014-7-9 18:59:07

该贴由hui.chen转至本版2014-11-5 16:11:47




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论