update跟select的表锁问题 (mysql myisam)
程序员文章站
2022-04-08 18:18:31
...
请问,某个页面被访问时,它需要先从表B里找出随机词的ID(字段:now_id),然后再去表A里查找这个随机词。
当从表B里select出这个随机词的ID(now_id)后,会now_id+1。
但现在的问题是,可能是因为瞬间的访问量很大,导致表B里update根本没完成就又select了。。。我很纳闷,,既然有update,不是应该update完之后才会select吗,,update会自动加写锁,然后应该等update执行完才可以执行select。
我现在想要让它update完再select,又不至于造成阻塞。。
当从表B里select出这个随机词的ID(now_id)后,会now_id+1。
但现在的问题是,可能是因为瞬间的访问量很大,导致表B里update根本没完成就又select了。。。我很纳闷,,既然有update,不是应该update完之后才会select吗,,update会自动加写锁,然后应该等update执行完才可以执行select。
我现在想要让它update完再select,又不至于造成阻塞。。
$sql = "select * from fan_keyword where id=(select fval from hao_fan_temp where fkey='keyword_produce_id' limit 1)";$result = mysql_query($sql);$arr = mysql_fetch_assoc($result);if(!empty($arr)){ $keyname = $arr['name']; $idd = intval($arr['id']) + 1;}else{ $sql = "select * from fan_keyword limit 1"; $result = mysql_query($sql); $arr = mysql_fetch_assoc($result); $keyname = $arr['name']; $idd = intval($arr['id']) + 1;} $sql1 = "update hao_fan_temp set fval='$idd' where fkey='keyword_produce_id'"; mysql_query($sql1) or exit('auto_produce: 保存当前抽取的词ID失败');
回复讨论(解决方案)
我想我搞错了,应该是select的时候有读锁,但是不阻塞同一时间其他进程的读操作,所以它读的还是之前的那个数据
推荐阅读
-
Mysql锁表的问题解决
-
MySQL中Update、select联用操作单表、多表,及视图与临时表的区别
-
select...for update在mysql和oracle间锁行为的比较_MySQL
-
mysql的锁表问题_MySQL
-
MySQL SELECT同时UPDATE同一张表问题发生及解决_MySQL
-
MySQL中select * for update锁表的问题
-
Mysql(MyISAM)的读写互斥锁问题的解决方法_MySQL
-
Mysql(MyISAM)的读写互斥锁有关问题的解决办法
-
mysql查询更新时的锁表机制分析(只介绍了MYISAM)_MySQL
-
mysql的行锁与表锁(select* .... FOR UPDATE)