JAVA语言之mysql表锁、行锁、索引之间暧昧的关系
赵泽红 2019-04-10 来源 : 阅读 421 评论 0

摘要:本文主要向大家介绍了JAVA语言之mysql表锁、行锁、索引之间暧昧的关系,通过具体的内容向大家展示,希望对大家学习JAVA语言有所帮助。

本文主要向大家介绍了JAVA语言之mysql表锁、行锁、索引之间暧昧的关系,通过具体的内容向大家展示,希望对大家学习JAVA语言有所帮助。

JAVA语言之mysql表锁、行锁、索引之间暧昧的关系

JAVA语言之mysql表锁、行锁、索引之间暧昧的关系

Mysql 领域的innodb存储引擎支持行级锁,innodb的行锁是通过给索引项加锁实现的,这就意味着只有通过索引条件检索数据时,innodb才使用行锁,否则使用表锁。

根据当前的数据更新语句(UPDATE user set name='11111' where account='1'),该条件字段account并没有添加索引,所以导致数据表被锁。

我们验证一下:

第一种情况,通过非索引条件检索数据时,使用的是表锁,会导致数据表被锁

1.首先,我们将mysql事务设置为不自动提交,mysql事务默认是自动提交事务的,1表示自动提交事务

mysql> select @@autocommit;
+--------------+| @@autocommit |+--------------+| 1 |+--------------+1 row in set
mysql> set autocommit = 0;
Query OK, 0 rows affected

2.起一个命令行,开始事务,更新第一条记录,先不提交

mysql> start transaction;Query OK, 0 rows affectedmysql> begin;
Query OK, 0 rows affectedmysql> UPDATE user set name='11111' where account='1' ->

3.我们再起一个命令行,更新第二条记录

UPDATE user set name='2222' where id='2'
4.看下表的数据

JAVA语言之mysql表锁、行锁、索引之间暧昧的关系

mysql表锁、行锁、索引之间暧昧的关系
mysql

可以看到,数据表没有更新

5.把第一个命令行的事务提交了

mysql> commit;Query OK, 0 rows affected

JAVA语言之mysql表锁、行锁、索引之间暧昧的关系

我们看到现在数据更新了。

第二种情况,通过索引条件检索数据时,使用的是行锁

如第一种情况,自己测试下。

本文由职坐标整理并发布,希望对同学们有所帮助。了解更多详情请关注编程语言JAVA频道!

本文由 @职坐标 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论
本文作者 联系TA

行是知之始,知是行之成,知行合一,方能大成。

  • 10
    文章
  • 1953
    人气
  • 100%
    受欢迎度

已有3人表明态度,100%喜欢该老师!

进入TA的空间
名师指导 直通车
  • 索取资料 索取资料 索取资料
  • 答疑解惑 答疑解惑 答疑解惑
  • 技术交流 技术交流 技术交流
  • 职业测评 职业测评 职业测评
  • 面试技巧 面试技巧 面试技巧
  • 高薪秘笈 高薪秘笈 高薪秘笈
TA的其他文章 更多>>
JAVA语言之Solr的工作原理以及如何管理索引库
经验技巧 100% 的用户喜欢
JAVA语言之Spring知识复习
经验技巧 0% 的用户喜欢
JAVA语言之Git内部原理之Git引用
经验技巧 0% 的用户喜欢
JAVA语言之Java 11 正式发布,这 8 个逆天新特性教你写出更牛逼的代码
经验技巧 0% 的用户喜欢
JAVA语言之Spring Boot(十三)RabbitMQ安装与集成
经验技巧 0% 的用户喜欢
其他海同名师 更多>>
刘新华
刘新华 联系TA
实力型。激情饱满,对专业充满热情
吴翠红
吴翠红 联系TA
独创“教、学、练、测”循环教学模式
吕益平
吕益平 联系TA
熟悉企业软件开发的产品设计及开发
黄泽民
黄泽民 联系TA
擅长javase核心技术
程钢
程钢 联系TA
擅长大型企业商业网站开发和管理
经验技巧30天热搜词 更多>>

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:13167058313
小职老师的微信号:13167058313

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    ICP许可  沪B2-20190160

站长统计