自建电商网站销售商品,办公空间设计原则,app软件开发用什么软件,网站怎么实现两种语言MySQL是开放源代码#xff0c;MySQL因为其速度、可靠性和适应性而备受关注。大多数人都认为在不需要事务化处理的情况下#xff0c;MySQL是管理内容最好的选择。 那么如何在MySQL实现表中取出随机数据呢#xff1f;SELECT * FROM table_name ORDER BY rand() LIMIT 5;rand在…MySQL是开放源代码MySQL因为其速度、可靠性和适应性而备受关注。大多数人都认为在不需要事务化处理的情况下MySQL是管理内容最好的选择。 那么如何在MySQL实现表中取出随机数据呢SELECT * FROM table_name ORDER BY rand() LIMIT 5;rand在手册里是这么说的:RAND()RAND(N)返回在范围0到1.0内的随机浮点值。如果一个整数参数N被指定它被用作种子值。mysql select RAND();- 0.5925mysql select RAND(20);- 0.1811mysql select RAND(20);- 0.1811mysql select RAND();- 0.2079mysql select RAND();- 0.7888你不能在一个ORDER BY子句用RAND()值使用列因为ORDER BY将重复计算列多次。然而在MySQL3.23中你可以做 SELECT * FROM table_name ORDER BY RAND()这是有利于得到一个来自SELECT * FROM table1,table2 WHERE ab 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 r2WHERE r1.id r2.idORDER BY r1.id ASCLIMIT 5;执行效率需要0.02 sec.可惜的是,只有mysql 4.1.*以上才支持这样的子查询.