MySQL如何从表中取出随机数据_MySql随机查询例子
2014-08-30 11:46:24  By: shinyuu

今天在做博客维护的时候、需要用到从数据库中随机查询几条博文出来

一开始我想用PHP的实现随机、然后到数据库里面查询、但取出多条好像要进行两次以上查询

在网上找了一下、总的分为两种方法、一种是直接使用 rand()、MySQL手册中找到了下面这个语句、可以完成任务


SELECT * FROM table_name ORDER BY rand() LIMIT 5;

但是效率非常低

rand在手册里是这么说的:


RAND()
RAND(N) 
返回在范围0到1.0内的随机浮点值、如果一个整数参数N被指定,它被用作种子值


mysql> select RAND();
-> 0.5925
mysql> select RAND(20);
-> 0.1811
mysql> select RAND(20);
-> 0.1811
mysql> select RAND();
-> 0.2079
mysql> select RAND();
-> 0.7888

你不能在一个ORDER BY子句用RAND()值使用列,因为ORDER BY将重复计算列多次

然而在MySQL3.23中,你可以做:


SELECT * FROM table_name ORDER BY RAND()

这是有利于得到一个集合的随机样本


SELECT * FROM table1,table2 WHERE a=b AND c

注意在一个WHERE子句里的一个RAND()将在每次WHERE被执行时重新评估
但我试了一下,2千条记录的表,执行一次需要0.02 sec,.慢了些
后来我在网上找资料找到如下代码


SELECT *
FROM table_name AS r1 JOIN
(SELECT ROUND(RAND() *
(SELECT MAX(id)
FROM table_name)) AS id)
AS r2
WHERE r1.id >= r2.id
ORDER BY r1.id ASC
LIMIT 5;


这种效率明显高于上面的方法、所以推荐采用这种方法

若资源对你有帮助、浏览后有很大收获、不妨小额打赏我一下、你的鼓励是维持我不断写博客最大动力

想获取DD博客最新代码、你可以扫描下方的二维码、关注DD博客微信公众号(ddblogs)

或者你也可以关注我的新浪微博、了解DD博客的最新动态:DD博客官方微博(dwtedx的微博)

如对资源有任何疑问或觉得仍然有很大的改善空间、可以对该博文进行评论、希望不吝赐教

为保证及时回复、可以使用博客留言板给我留言: DD博客留言板(dwtedx的留言板)

感谢你的访问、祝你生活愉快、工作顺心、欢迎常来逛逛


快速评论


技术评论

  • 该技术还没有评论、赶快抢沙发吧...
DD记账
top
+