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

相关推荐
2501_941111347 分钟前
实战:用OpenCV和Python进行人脸识别
jvm·数据库·python
q***040511 分钟前
MySQL 数据类型详解:TINYINT、INT 和 BIGINT
数据库·mysql
e***582315 分钟前
MySQL如何执行.sql 文件:详细教学指南
数据库·mysql
z***33516 分钟前
redis清理缓存
数据库·redis·缓存
CS_浮鱼22 分钟前
【Linux】进程间通信
linux·运维·数据库
2501_9411115127 分钟前
Python多线程与多进程:如何选择?(GIL全局解释器锁详解)
jvm·数据库·python
2501_9411113335 分钟前
使用Python处理计算机图形学(PIL/Pillow)
jvm·数据库·python
♡喜欢做梦36 分钟前
MyBatis操作数据库(入门)
java·数据库·mybatis
敲上瘾1 小时前
MySQL事务全攻略:ACID特性、隔离级别与并发控制
linux·数据库·mysql·安全
懒羊羊不懒@1 小时前
【MySQL | 基础】事务
数据库·mysql