如何主动加锁?

BATTLERxANGE 2014-11-26 08:39:00
我有一个MYSQL数据库,分布式的应用层,这些应用层会先查询数据库里的一条数据,
1:如果没有就插入
2:有就读出来

在情况1的时候,插入的主键是一个字符串,并发情况下这个字符串都是一样的。在插入这条数据后,还要执行一些逻辑,这些逻辑可能需要花费数秒时间。但是要求在这个逻辑执行完以前,如果其他应用层在查询这条数据的话就阻塞起来。
这样的并发和锁应该怎么做?然后又是如何保证在并发的情况下,“如果没有就插入,有就读出来”不会产生冲突?比如一开始查了是没有,然后插入,但是因为其他应用层也再查询没有后进行插入,结果造成并发冲突,如何解决?
...全文
278 5 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
ACMAIN_CHM 2014-11-27
  • 打赏
  • 举报
回复
lock table 语句。
九月茅 2014-11-27
  • 打赏
  • 举报
回复
可以试试 select ... for update;
BATTLERxANGE 2014-11-27
  • 打赏
  • 举报
回复
引用 3 楼 ACMAIN_CHM 的回复:
lock table 语句。
这样性能会不会太低?我的并发量比较大。。。
BATTLERxANGE 2014-11-26
  • 打赏
  • 举报
回复
引用 1 楼 kimsung 的回复:
应用层用一个MQ之类的不行吗?
MQ是什么?分布式的应用层之间没办法用锁。。。
kimsung 2014-11-26
  • 打赏
  • 举报
回复
应用层用一个MQ之类的不行吗?

56,937

社区成员

发帖
与我相关
我的任务
社区描述
MySQL相关内容讨论专区
社区管理员
  • MySQL
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧