MySQL中随机select记录

我有这个需求:

数据库中的uid离散分布不连续,需要随机select某一条记录。

1、最懒做法

这个非常慢,因为几乎要遍历整个表。

2、用id随机范围。

其实如果我们能得到min(uid)和max(uid),然后随机这之间的某一个ID,再where >= 就可以了。

首先是获取min和max的uid:

然后是获取[min, max]之间的随机数。

上面这句执行非常慢,

需要优化:

然后加上where

最后这句非常快了。

 

 

Leave a Reply

Your email address will not be published.