专注于互联网--专注于架构

最新标签
网站地图
文章索引
Rss订阅

首页 »数据库 » mysql随机取数据:MySQL实现表中取出随机数据 »正文

mysql随机取数据:MySQL实现表中取出随机数据

来源: 发布时间:星期四, 2009年2月12日 浏览:342次 评论:0



  以前在群里讨论过这个问题,比较有意思.mysql语法真好玩.他们原来都想用PHP实现随机,但取出多条好像要进行两次以上查询.翻了手册,找到了下面这个语句,可以完成任务了
  
  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<d ORDER BY RAND LIMIT 1000集合随机样本注意在个WHERE子句里个RAND将在每次WHERE被执行时重新评估
  
  但我试了下,8千条记录表,执行次需要0.08 sec,.慢了些
  
  后来请教了google,得到如下代码
  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;
  
  执行效率需要0.02 sec.可惜是,只有mysql 4.1.*以上才支持这样子查询.
0

相关文章

读者评论

发表评论

  • 昵称:
  • 内容: