>백엔드 개발 >PHP 튜토리얼 >请问并发写入数据库,如何保持唯一性啊

请问并发写入数据库,如何保持唯一性啊

WBOY
WBOY원래의
2016-06-23 13:59:211304검색


//a,b两个请求并发  注册相同用户名 username='myname'$is_user = "SELECT username FROM users WHERE username='myname'";if(!$is_user){	echo ("INSERT INTO users (username) VALUES ('myname')");}


假如表中字段未设置唯一索引,程序上如何控制唯一性啊
a,b同时查询表,结果是可以注册的,所以都执行了insert,但用户名相同,这样数据就不唯一了。是会这样吗,如何避免呢?


回复讨论(解决方案)

数据库加锁操作

数据库加锁操作
读锁  好像是共用的啊,大家可以同时读,所以出现了错误结果。

怎么不加个unique key呢。

最简单的方法数据库加unique key

复杂一点:
单台web机器,使用本地文件锁flock,一个用户名一个本地文件
多台机器 ,使用memcache inc 实现锁机制 http://ju.outofmemory.cn/entry/48924

了解了,谢谢各位。

我也只是偶尔想到的,如果不是唯一索引,用什么方法来解决这个问题。

最简单的方法数据库加unique key

复杂一点:
单台web机器,使用本地文件锁flock,一个用户名一个本地文件
多台机器 ,使用memcache inc 实现锁机制 http://ju.outofmemory.cn/entry/48924
再请教一下 memcache。

$v = $memcache->get ( $key );
if ($v === false) {
$memcache->set ( $key, 0 );
}
$index = $memcache->increment ( $key, 1 );

两个并发请求a,b   会同时get($key)吗
然后a set($key),再b set($key) 不就被后者覆盖了吗

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.