黑帽联盟

 找回密码
 会员注册
查看: 111|回复: 0
打印 上一主题 下一主题

[mysql] InnoDB select操作会锁表吗?是行锁还是表锁?

[复制链接]

895

主题

38

听众

3329

积分

管理员

Rank: 9Rank: 9Rank: 9

  • TA的每日心情
    难过
    昨天 22:31
  • 签到天数: 1652 天

    [LV.Master]伴坛终老

    故事背景
    今天朋友说操作mysql超时了,我首先想到的是环境的问题。我问是不是数据源配错了,他给我的答案是否定的。然后查了下日志:java.sql.SQLException: Lock wait timeout exceeded; try restarting transaction。跟踪到是下面SQL导致的表锁 SELECT * FROM t_cms_promotion t WHERE t.pro_des = #{description} FOR UPDATE


    innodb锁机制
    innodb默认是行锁,前提条件是建立在索引之上的。如果筛选条件没有建立索引,会降级到表锁。即如果where条件中的字段都加了索引,则加的是行锁;否则加的是表锁。下面我们从几个方面对比下行锁和表锁



    表1
    对比方向 行锁 表锁
    锁定粒度
    是否会发生死锁不会
    锁冲突概率
    并发数
      开销



    在加锁的时候,mysql有读锁和写锁,为了说明如何使用,在此举以下例子:


    读锁(共享锁):允许其他线程上读锁,但是不允许上写锁;
    SELECT * FROM t_cms_promotion t WHERE t.pro_id = ? LOCK IN SHARE MODE

    写锁(排他锁):不允许其他线程上任何锁。
    SELECT * FROM t_cms_promotion t WHERE t.pro_id = ? FOR UPDATE

    注:如果让以上SQL语句上行锁,查询条件pro_id需要建立索引

    帖子永久地址: 

    黑帽联盟 - 论坛版权1、本主题所有言论和图片纯属会员个人意见,与本论坛立场无关
    2、本站所有主题由该帖子作者发表,该帖子作者与黑帽联盟享有帖子相关版权
    3、其他单位或个人使用、转载或引用本文时必须同时征得该帖子作者和黑帽联盟的同意
    4、帖子作者须承担一切因本文发表而直接或间接导致的民事或刑事法律责任
    5、本帖部分内容转载自其它媒体,但并不代表本站赞同其观点和对其真实性负责
    6、如本帖侵犯到任何版权问题,请立即告知本站,本站将及时予与删除并致以最深的歉意
    7、黑帽联盟管理员和版主有权不事先通知发贴者而删除本文

    勿忘初心,方得始终!
    您需要登录后才可以回帖 登录 | 会员注册

    发布主题 !fastreply! 收藏帖子 返回列表 搜索
    回顶部