MySQL完成表中掏出随机数据

  泉源:站长资讯  




从前在群里批判辩论过这个题目,对比的存心思.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;





版权声明: 原创作品,容许转载,转载时请务必以超链接编制标明文章 原始理由 、作者信息和本声明。不然将清查纪律责任。

原文地址:https://www.cnblogs.com/zgqjymx/p/1975713.html