关于现场随机抽奖的问题.

[复制链接]
查看11 | 回复3 | 2021-1-27 05:31:20 | 显示全部楼层 |阅读模式
现场由主持人抽奖,4万个订单,金额满100元,有一次抽奖机会。
比如:A客户交了300元,B客户100元,C客户50元,那么:
A=3次机会
B=1次机会
C=0没有机会
我之前的算法是:
从数据库中读取符合条件的订单客户
把客户按订单规则存入数组,如:
$user=array('a','a','a','b');;
$isNum=mt_rand(0,count($user)-1);
$isLottery=$user[$isNum];
但是现在这个数据非常大,如果用这个算法,感觉不适合。
请问有没有什么好的想法和思路
分 -->
回复

使用道具 举报

千问 | 2021-1-27 05:31:20 | 显示全部楼层
直接除,再取整数,。
回复

使用道具 举报

千问 | 2021-1-27 05:31:20 | 显示全部楼层
这个用数据库去算要快得多,为啥要在前端算啊
回复

使用道具 举报

千问 | 2021-1-27 05:31:20 | 显示全部楼层
引用2楼shinger126的回复:这个用数据库去算要快得多,为啥要在前端算啊
这个我是在php后端算.但是我不知道怎么写这个sql,我问题一些人.说rand()及分组.但是我不知道怎么写.
比如:selectcustomer_id,floor(SUM(price/100))fromorderswhereprice>=100groupbycustomer_idorderbyrand()
但是怎么按一订单多的机会越多来抽呢?
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

主题

0

回帖

4882万

积分

论坛元老

Rank: 8Rank: 8

积分
48824836
热门排行