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

相关推荐
2401_83203534几秒前
使用Python处理计算机图形学(PIL/Pillow)
jvm·数据库·python
roman_日积跬步-终至千里1 分钟前
【论文ing】强化学习重塑 NL2SQL:单轮对齐、多轮交互与细粒度评估的最新进展(2020–2026)
数据库·sql·microsoft
杨超越luckly1 分钟前
AI Agent应用指南 :自动化构建品牌数据库:提示词 + API + 结构化输出
大数据·数据库·人工智能·自动化·ai agent
写代码的小阿帆2 分钟前
MySQL多表联查——内连、外连
数据库·mysql
九章-2 分钟前
金仓数据库迁移工具链:Oracle平滑迁移的技术实践
数据库·oracle·数据库迁移工具·oracle迁移工具
逍遥德2 分钟前
Postgresql explain执行计划详解
数据库·后端·sql·postgresql·数据分析
空空潍2 分钟前
PostgreSQL保姆级下载安装指南(win版)
数据库·postgresql
海山数据库3 分钟前
移动云大云海山数据库(He3DB)与PolarDB架构深度对比(一)
数据库·架构·he3db·大云海山数据库·移动云数据库
dapeng28704 分钟前
Django全栈开发入门:构建一个博客系统
jvm·数据库·python
TG_yunshuguoji4 分钟前
阿里云代理商:怎么创建和连接RDS云数据库?
数据库·阿里云·云计算