当前位置: 首页 > 图文教程 > 数据库 > MYSQL > 如何实现MySQL表数据随机读取

MYSQL
实际应用:MySQL5存储过程编写
解决MySQL server has gone away
如何关闭MySQL数据库中错误提示音
解决MySQL中忽略用户的现象
带你轻松接触MySQL数据库的异常处理
MySQL字符集:保证不发生乱码的方法
如何对MySQL 服务器进行调优
MySQL忘记超级用户口令的解决办法
一个检测MySQL状态的脚本
公共MySQL的数据库服务器层
Linux下MySQL数据库开发技术
Mysql基础教程:新手上路操作必看
Mysql教程 对MySQL中的锁机制的总结
巧实例:如何在.NET中访问MySQL数据库
PHP和MYSQL数据库合理且有效的结合在一起
MySQL数据库中修改密码访问限制设置详解
解析PHP连接MYSQL的两种方法
mysql 8小时空闲后连接超时的问题
如何加大MYSQL中的最大连接数
SQL实现动态交叉表

MYSQL 中的 如何实现MySQL表数据随机读取


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 80 ::
收藏到网摘: n/a

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