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

相关推荐
牛马鸡niumasi16 小时前
Mysql:事务管理(上)
数据库·mysql
IMPYLH16 小时前
Linux 的 users 命令
linux·运维·服务器·前端·数据库·bash
Nontee16 小时前
三大范式是什么?
java·前端·数据库
步十人17 小时前
【MySQL】进阶01-存储引擎
数据库·mysql
六月雨滴17 小时前
归档日志备份
数据库·oracle·dba
白露与泡影17 小时前
自己用 ai 写了个链接 mysql 数据库的 mcp 工具
数据库·人工智能·mysql
我是一颗柠檬17 小时前
【MySQL全面教学】MySQL聚合函数与分组Day5(2026年)
数据库·后端·mysql·database
牛马鸡niumasi17 小时前
Mysql:事务管理(中)
数据库·mysql
字节高级特工17 小时前
Redis事务:简单但实用的打包执行
数据库·redis·后端·缓存
GISer_Jing17 小时前
后端系统稳定性基石:数据库设计、接口幂等性与边界case处理全链路实战
数据库·oracle·架构