MySQ中Select * for update用法的示例分析

发布时间:2021-11-30 14:59:56 作者:柒染
来源:亿速云 阅读:214

本篇文章为大家展示了MySQ中Select * for update用法的示例分析,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

今天有个小伙伴问我Mysql什么时候需要使用悲观锁,也就是在执行语句的时候带上For  Update。教科书告诉我们,在一些对数据要求严格的,并且有着并发问题的场景。那么,是什么样的场景呢?

我举一个例子,我们在网上买票,从锁定座位到出票其实是一个比较“漫长”的过程,那么就存在这样一个业务场景,可能在我们锁定座位的时候,另外一个事务把这场电影停售了。那么,接下来的事务执行,就可能会出现一些异常。

因为我们在执行购票的时候,虽然也需要查询电影的在售状态,但由于我们只是查询电影的在售状态,所以只能取到该行数据的一个读锁,除非事务级别为串行化,不然别的事务仍然可以对该行数据进行修改。所以,即便我们只是一个读操作,我们仍然希望对该行数据加上一个锁,让别的事务只能读取,而无法修改该行数据,这就是数据库的悲观锁。

我们可以使用Select * for update 这样的姿势来使用这个功能。要注意到,这个不同的使用方法,我们的锁级别是不一样的。

  1. 明确指定主键,并且主键存在,那么这是一个行级锁,如果主键不存在,那么并不会加锁。如果明确指定的是索引,那么满足该索引的所有行都会加上锁。

  2. 如果select条件中并没有命中主键或者索引,那么这将是一个表级锁,也就是整个表的数据都不能够变更,但是可以新插入数据。另外一种情况,是没有正确的使用到索引,例如使用不等于,like作为筛选条件。要注意的是,如果悲观锁锁表的话,并发将会大大降低,所以,使用for  update的时候,切记要检查是否命中索引。

上述内容就是MySQ中Select * for update用法的示例分析,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注亿速云行业资讯频道。

推荐阅读:
  1. javascript中for in与in的用法
  2. js中forEach,for in,for of循环的用法示例小结

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

mysql

上一篇:Java对象的序列化和反序列化举例分析

下一篇:C/C++ Qt TreeWidget单层树形组件怎么应用

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》