问一个mysql的锁的问题?mysql同时写数据会怎么样?

WBOY
發布: 2016-06-06 20:23:12
原創
1235 人瀏覽過

不考虑事务的情况,就单纯普通(没有锁)的sql

1:如果一个查询操作和一条写的操作同时执行怎么办,mysql会自动加锁吗?

2:如果两个或者多个查询的操作同时执行怎么办?

3:如果两个写的操作同时执行怎么办?

3:如果一个读,一个同时写怎么办?

不考虑事务的情况。

回复内容:

不考虑事务的情况,就单纯普通(没有锁)的sql

1:如果一个查询操作和一条写的操作同时执行怎么办,mysql会自动加锁吗?

2:如果两个或者多个查询的操作同时执行怎么办?

3:如果两个写的操作同时执行怎么办?

3:如果一个读,一个同时写怎么办?

不考虑事务的情况。

给自己补充回答:
1:innodb不同的select没有任何锁,Myisam会自动加表共享读锁;

2:innodb没有锁所以是没有任何问题的,Myisam是表共享读锁,共享读锁相互没有冲突,是并行的;

3:Myisam是加的表独占写锁,表级锁,是串行的,写锁会相互阻塞,必须写的sql是一条一条执行的。innodb情况就复杂一点了,innodb采用的是行锁,当然还跟索引有关(影响加锁),会自动加行排它锁:

排他锁(X):允许获得排他锁的事务更新数据,阻止其他事务取得相同数据集的共享读锁和排他写锁。

所以如果没有行锁冲突则相互没有影响,否则会出现锁阻塞。

,锁粒度不同也可能会出现死锁,即为:相互等待锁会发生死锁,当一个事物发现它要等的释放锁的事务同时也在等待它释放锁时,它就会发生死锁退出,释放锁,让前者得到锁;

4:对于普通SELECT语句,InnoDB不会加任何锁,所以读写同时进行没有问题,读为快照读,写为当前读;对于Myisam看哪个进程先获得表锁,读写是串行的。

参考:http://blog.csdn.net/xifeijian/article/details/20313977
参考:http://blog.csdn.net/xifeijian/article/details/20312557

自动加锁,update是原子操作

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!