首頁 > 後端開發 > php教程 > 请教并发写入数据库,怎么保持唯一性

请教并发写入数据库,怎么保持唯一性

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
發布: 2016-06-13 11:54:24
原創
1501 人瀏覽過

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

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


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


------解决方案--------------------
数据库加锁操作
------解决方案--------------------
怎么不加个unique key呢。
------解决方案--------------------
最简单的方法数据库加unique key

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

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
javascript - js正規符合特定字串
來自於 1970-01-01 08:00:00
0
0
0
為什麼說非物件呼叫成員函數fetch()
來自於 1970-01-01 08:00:00
0
0
0
資料庫設定檔必須要用二維數組
來自於 1970-01-01 08:00:00
0
0
0
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板