设为首页
收藏本站
开启辅助访问
切换到窄版
登录
立即注册
中问网首页
我的收藏
站长博客
搜索
搜索
本版
帖子
用户
第一问答网
»
论坛
›
中问网
›
问答
›
关于现场随机抽奖的问题.
返回列表
发新帖
关于现场随机抽奖的问题.
[复制链接]
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()
但是怎么按一订单多的机会越多来抽呢?
回复
使用道具
举报
返回列表
发新帖
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
立即注册
本版积分规则
发表回复
回帖后跳转到最后一页
千问
主题
0
回帖
4882万
积分
论坛元老
论坛元老, 积分 48824836, 距离下一级还需 -38824837 积分
论坛元老, 积分 48824836, 距离下一级还需 -38824837 积分
积分
48824836
加好友
发消息
回复楼主
返回列表
问答
热门排行