,从前在群里批判辩论过这个题目,对比的存心思.mysql的语法真好玩.他们原本都想用PHP的完成随机,但掏出多条好像要终






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






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