Mysql入门MySQL查询随机数据的4种方法和性能对比
发布时间:2020-12-12 01:04:47 所属栏目:MySql教程 来源:网络整理
导读:《Mysql入门MySQL查询随机数据的4种方法和性能对比》要点: 本文介绍了Mysql入门MySQL查询随机数据的4种方法和性能对比,希望对您有用。如果有疑问,可以联系我们。 下面从以下四种方案分析各自的优缺点. 方案一: 代码如下:SELECT * FROM `table` ORDER BY
《Mysql入门MySQL查询随机数据的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% 方案三 C 13% 方案四 C 16% so,方案三胜出! (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- Mysql必读mySQL占用虚拟内存达8百多兆问题解决思路
- MYSQL数据库Mysql服务器的启动与停止(二)
- MySQL查询速度慢…有时候
- Mysql学习Centos 6.4源码安装mysql-5.6.28.tar.gz教程
- MYSQL数据库如何将MySQL的两个表名对调
- Mysql必读完全卸载mysql(停止服务、卸载相关程序、删除注册
- Mysql实例MySQL 5.6 中TIMESTAMP with implicit DEFAULT va
- MYSQL教程MySQL 5.7 zip版本(zip版)安装配置步骤详解
- python – 插入mysql数据库时间戳
- Mysql学习MySQL 5.5 range分区增加删除处理的方法示例