您好,匿名用户
随意问技术百科期待您的加入

关于mysql的锁表

0 投票

一般都来都会使用
lock table
然后在
unlock

但是今天google的时候发现还可以用 for update 进行行锁

这样就产生了一个疑问

如果我是select 一群数据,是不是我就是把这群数据全部锁住了

为了防止并发,一般是锁整个表还是锁住部分的数据?

用户头像 提问 2012年 12月1日 @ Tryndamere 上等兵 (325 威望)
分享到:

1个回答

0 投票

在数据库那端,取决于存储引擎。MyISAM引擎是直接锁表(只有表级的锁),InnoDB支持行锁。

如果存储引擎支持的话,取决于你的业务需求。

一般来说,锁的粒度越小越好,前提是要满足性能需求。

用户头像 回复 2012年 12月1日 @ Ryze 上等兵 (293 威望)
提一个问题:

相关问题

0 投票
1 回复 39 阅读
用户头像 提问 2012年 12月1日 @ Artemis 上等兵 (162 威望)
0 投票
1 回复 35 阅读
用户头像 提问 2012年 12月1日 @ Leona 上等兵 (279 威望)
0 投票
1 回复 41 阅读
+1 投票
1 回复 122 阅读
用户头像 提问 2012年 12月1日 @ Taurus 上等兵 (303 威望)
0 投票
1 回复 64 阅读

欢迎来到随意问技术百科, 这是一个面向专业开发者的IT问答网站,提供途径助开发者查找IT技术方案,解决程序bug和网站运维难题等。
温馨提示:本网站禁止用户发布与IT技术无关的、粗浅的、毫无意义的或者违法国家法规的等不合理内容,谢谢支持。

欢迎访问随意问技术百科,为了给您提供更好的服务,请及时反馈您的意见。
...