您当前的位置: 首页 > 数据库教程 > MySQL教程 > MySQL查询随机数据的4种方法和性能对比

MySQL查询随机数据的4种方法和性能对比

作者:不详 来源:网络 发布时间: 2014-07-17 12:33 点击:
从MySQL随机选取数据也是我们最常用的一种发发,其最简单的办法就是使用ORDER BY RAND(),本文介绍了包括ORDER BY RAND()的4种获取随机数据的方法,并分析了各自的优缺点。 下面从以下四种方案分析各自的优缺点。 方案一: 代码如下:SELECT * FROM `table` ORDER BY RAN

MySQL查询随机数据的4种方法和性能对比

  从MySQL随机选取数据也是我们最常用的一种发发,其最简单的办法就是使用”ORDER BY RAND()”,本文介绍了包括ORDER BY RAND()的4种获取随机数据的方法,并分析了各自的优缺点。

  下面从以下四种方案分析各自的优缺点。

  方案一:

  代码如下:SELECT * FROM `table` ORDER BY RAND() LIMIT 0,1;

  这种方法的问题就是非常慢。原因是因为MySQL会创建一张零时表来保存所有的结果集,然后给每个结果一个随机索引,然后再排序并返回。

  有几个方法可以让它快起来。

  基本思想就是先获取一个随机数,然后使用这个随机数来获取指定的行。

  由于所有的行都有一个唯一的id,我们将只取最小和最大id之间的随机数,然后获取id为这个数行。为了让这个方法当id不连续时也能有效,我们在最终的查询里使用”>=”代替”=”。

  为了获取整张表的最小和最大id,我们使用MAX()和MIN()两个聚合函数。这两个方法会返回指定组里的最大和最小值。在这里这个组就是我们表里的所有id字段值。

  方案二:

  代码如下:<?php

  $range_result = mysql_query( " SELECT MAX(`id`) AS max_id , MIN(`id`) AS min_id FROM `table` ");

  $range_row = mysql_fetch_object( $range_result );

  $random = mt_rand( $range_row->min_id , $range_row->max_id );

  $result = mysql_query( " SELECT * FROM `table` WHERE `id` >= $random LIMIT 0,1 ");

  就像我们刚才提到的,这个方法会用唯一的id值限制表的每一行。那么,如果不是这样情况怎么办?

  下面这个方案是使用了MySQL的LIMIT子句。LIMIT接收两个参数值。第一个参数指定了返回结果第一行的偏移量,第二个参数指定了返回结果的最大行数。偏移量指定第一行是0而不是1。

  为了计算第一行的偏移量,我们使用MySQL的RAND()方法从0到1之间生成一个随机数。然后我们把这个数字跟我们用COUNT()方法获取倒的表记录数相乘。由于LIMIT的参数必须是int型而不能是float,我们使用FLOOR()来处理结果。FLOOR()会计算小于表达式的最大值。最终的代码就是这样:

  方案三:

  代码如下:<?php

  $offset_result = mysql_query( " SELECT FLOOR(RAND() * COUNT(*)) AS `offset` FROM `table` ");

  $offset_row = mysql_fetch_object( $offset_result );

  $offset = $offset_row->offset;

  $result = mysql_query( " SELECT * FROM `table` LIMIT $offset, 1 " );

  在MySQL 4.1以后我们可以使用子子查询合并上面两个方法:

  方案四:

  代码如下:SELECT * FROM `table` WHERE id >= (SELECT FLOOR( MAX(id) * RAND()) FROM `table` ) ORDER BY id LIMIT 1;

  这个方案跟方案二有同样的弱点,只对有唯一id值的表有效。

  记住我们最初寻找选择随机行的替代方法的原因,速度!所以,这些方案的在执行时间上的比较会怎么样?我不会指出硬件和软件配置或者给出具体的数字。大概的结果是这样的:

  最慢的是解决方案一(我们假定它用了100%的时间)。

  方案二用了79%

  方案三 – 13%

  方案四 – 16%

  so, 方案三胜出!
分享到:
本文"MySQL查询随机数据的4种方法和性能对比"由远航站长收集整理而来,仅供大家学习与参考使用。更多网站制作教程尽在远航站长站。
顶一下
(0)
0%
踩一下
(0)
0%
[点击 次] [返回上一页] [打印]
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
用户名: 密码: 验证码:
关于本站 - 联系我们 - 网站声明 - 友情连接- 网站地图 - 站点地图 - 返回顶部
Copyright © 2007-2013 www.yhzhan.com(远航站长). All Rights Reserved .
远航站长:为中小站长提供最佳的学习与交流平台,提供网页制作与网站编程等各类网站制作教程.
官方QQ:445490277 网站群:26680406 网站备案号:豫ICP备07500620号-4