mysql随机取数据优化

mysql表中随机取三条数据。

本来是打算用:

select * from table order by rand() limit 3

结果40W的表查询要2.6秒,速度贼慢。每条记录都调用了rand()行数来排序

后来发现mysql官方手册也不推荐这种做法,找到下面这种方法:

SELECT * FROM table  AS t1 JOIN (SELECT ROUND(RAND() * (SELECT MAX(id) FROM table)) AS id) AS t2 WHERE t1.id >= t2.id
ORDER BY t1.id ASC LIMIT 3

不过这种方式不适用,它需要一个自增注解,而我的表主键是uuid。而且不均匀

后来又在网上找到下面这种方法

SELECT * FROM table WHERE id IN 
(SELECT id FROM (SELECT id FROM table ORDER BY rand() LIMIT 3) t)

查询只要0.3秒,效果贼好。原因是因为排序时只把id加载到内存,在sort buffer中排序,没有加载所有字段,减少了磁盘读取。而为什么用两层查询是因为这个:

mysql不支持在in里面放子查询(/ □ \)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

山间明月江上清风_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值