随机数算法,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 返回第一条

相关推荐
龚礼鹏3 分钟前
图像显示框架十一——BufferQueue的工作流程(基于Android 15源码分析)
java·网络·数据库
diediedei13 分钟前
用Pygame开发你的第一个小游戏
jvm·数据库·python
程序员后来15 分钟前
Redis基本数据类型及其应用:从原理到实战的完整指南
数据库·redis·缓存
2301_7903009615 分钟前
用Python制作一个文字冒险游戏
jvm·数据库·python
naruto_lnq19 分钟前
使用Seaborn绘制统计图形:更美更简单
jvm·数据库·python
xuefuhe23 分钟前
postgresql之patroni高可用
数据库·postgresql
m0_7487080527 分钟前
将Python Web应用部署到服务器(Docker + Nginx)
jvm·数据库·python
惊鸿Randy28 分钟前
Docker 环境下 PostgreSQL 16 安装 pgvector 向量数据库插件详细教程(Bitnami 镜像)
数据库·docker·postgresql
定偶34 分钟前
USB协议
c语言·网络·数据库