Home >Backend Development >PHP Tutorial >update跟select的表锁问题 (mysql myisam)

update跟select的表锁问题 (mysql myisam)

WBOY
WBOYOriginal
2016-06-23 13:42:001607browse

请问,某个页面被访问时,它需要先从表B里找出随机词的ID(字段:now_id),然后再去表A里查找这个随机词。

当从表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的时候有读锁,但是不阻塞同一时间其他进程的读操作,所以它读的还是之前的那个数据

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn