> 백엔드 개발 > PHP 튜토리얼 > update跟select的表锁问题 (mysql myisam)

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

WBOY
풀어 주다: 2016-06-23 13:42:00
원래의
1643명이 탐색했습니다.

请问,某个页面被访问时,它需要先从表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的时候有读锁,但是不阻塞同一时间其他进程的读操作,所以它读的还是之前的那个数据

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿