随机数算法,SQL

sql 复制代码
SELECT
    * 
FROM
    prizes_config 
WHERE
    weight > ( SELECT FLOOR( RAND() * MAX( weight )) FROM prizes_config ) 
    order by weight asc
    
    
--    LIMIT 1;

记录

id 权重

1 5

2 10

3 50

4 100

找权重最大的那个值,调用rand()函数,它会随机生成一个0-1的值

然后 rand * 100 得出一个随机值

它的范围 0 <= 随机值 < 100

例如本次随机值为2,那么找到 大于2的所有记录,然后升序

此时查询结果为

2 10

3 50

4 100

最后LIMIT 1 返回第一条

相关推荐
u***096411 分钟前
MySQL索引优化
数据库·mysql
A***279515 分钟前
MySQL外键约束导致的删除失败问题
数据库·mysql
共享家952726 分钟前
QT-系统(多线程)
开发语言·数据库·qt
dessler36 分钟前
MYSQL-物理备份(xtrabackup)使用指南
linux·数据库·mysql
5***262036 分钟前
MySQL存储过程优化实例
数据库·mysql
hans汉斯41 分钟前
基于改进YOLOv11n的无人机红外目标检测算法
大数据·数据库·人工智能·算法·yolo·目标检测·无人机
r***11331 小时前
【玩转全栈】----Django模板语法、请求与响应
数据库·python·django
冉冰学姐2 小时前
SSM计算机课程在线教育服务平台xpwo1(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库
G***E3162 小时前
MySQL增强现实案例
数据库·mysql·ar
settingsun12252 小时前
分布式系统架构:SQL&NoSQL
sql·架构·nosql