视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
MySQL实现表中取出随机数据_MySQL
2020-11-09 17:00:57 责编:小采
文档


  以前在群里讨论过这个问题,比较的有意思.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  
  但我试了一下,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.*以上才支持这样的子查询.

下载本文
显示全文
专题