首頁 > 後端開發 > php教程 > 求php高并发下抽奖程序,如何处理重复中奖及多人抽中同一个奖

求php高并发下抽奖程序,如何处理重复中奖及多人抽中同一个奖

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
發布: 2016-06-13 12:35:37
原創
1346 人瀏覽過

求php高并发下抽奖程序,如何避免重复中奖及多人抽中同一个奖?
我的做法是比如:一等奖:1个,二等奖:2个,三等级:3个,这样有奖项为6,假如100人同时参与抽奖,那么空奖项为100-6=94项。

首先从数据库mysql查询出有奖项6个的唯一编号作为兑奖号:
sql1:
$sql="select 唯一编号 from table where status=0";
得到数组$real=array('001','002','003','004','005','006',);其中001,002就是唯一编号

然后生成94个空奖
$empty=array('','',...,'',);

最后把数组合并,得到一个全新的数组。
$arr = array_merge($real, $empty);

用户随机在数组中抽取一项
$rand= mt_rand(0, count($arr)-1);

比如$rand抽到了001
if(''!=$rand){
//表示抽中,修改数据状态,这里需要操作数据库

sql2:
$sql="update table set status=1 where 唯一编号=001";
操作完成

}else{
//表示没有抽中,不做操作。
}



现在的问题是当100人同时进入抽奖,在红色部分sql2,还没有来的急修改状态的情况下,sql1继续会把001作为没有抽中的奖项,来让其他用户继续抽,这样有可能001再次被抽到。

想请大家帮助php高并发下抽奖程序,如何避免重复中奖及多人抽中同一个奖?

或者从别的思路出发考虑抽奖程序。

并发 php 抽奖
相關標籤:
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡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
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板