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

WBOY
풀어 주다: 2016-06-13 11:37:35
원래의
1068명이 탐색했습니다.

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