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的留言板)
感谢你的访问、祝你生活愉快、工作顺心、欢迎常来逛逛