搜索
系统检测到您的用户名不符合规范:

Mysql InnoDB行锁不使用索引锁表的时候会锁整张表

浏览:7481 发布日期:2016年08月31日 分类:技术分享 关键字: mysql 行锁
如果使用针对InnoDB的表使用行锁,被锁定字段不是主键,也没有针对它建立索引的话。行锁锁定的也是整张表。锁整张表会造成程序的执行效率会很低。
具体测试步骤如下:
1. 创建测试表

注意表类型设置成为InnoDB
2. 插入测试数据

3. 不使用索引的情况,线程1进行查询结果如下

这时候来启动另一个查询窗口,使用线程2进行查询

发现虽然查询条件不一样,但是记录同样被锁死,查询不到结果,线程1进行事务提交后,线程2显示查询结果。所以查询1进行的不是行锁而是表锁。
4. 对nickname字段建立索引

重复步骤3,发现查询结果显示出来了,证明有索引的情况下,行锁生效了。




最佳答案
评论() 相关
后面还有条评论,
评论支持使用[code][/code]标签添加代码
您需要登录后才可以评论 登录 | 立即注册
收藏
唯╃珂
积分:2041 等级:LV3
热点推荐
(追記) (追記ここまで)
最新更新

我们

合作

网站

信息

ThinkPHP 是一个免费开源的,快速、简单的面向对象的 轻量级PHP开发框架 ,创立于2006年初,遵循Apache2开源协议发布,是为了敏捷WEB应用开发和简化企业应用开发而诞生的。ThinkPHP从诞生以来一直秉承简洁实用的设计原则,在保持出色的性能和至简的代码的同时,也注重易用性。并且拥有众多的原创功能和特性,在社区团队的积极参与下,在易用性、扩展性和性能方面不断优化和改进,已经成长为国内最领先和最具影响力的WEB应用开发框架,众多的典型案例确保可以稳定用于商业以及门户级的开发。

AltStyle によって変換されたページ (->オリジナル) /