mysql 如何选择随机行
2014-05-04 10:14
274 查看
最简单的方式是使用 mysql 的 ORDER BY RAND() 子句。
SELECT col1 FROM tbl ORDER BY RAND() LIMIT 10; 它能很好的运行在小表中。然而,对于大表,生成随机列表行时将产生一个严重的性能问题,MYSQL 需要对每一行进行随机,然后对它们排序。 即使你只想从10W的结果集中取其中随机10行,MySQL也需要对这10W行进行排序并且只提取其中的10行。 为了解决这个问题,我在 WHERE 子句中使用 RAND 并且不使用ORDER BY 子句。首先,你需要计算表中的总行数和你想要的得到随机行数。其次,在 WHERE 子句中加入该碎片数字,并要求结果只能小于(或等于)从这个碎片数字。
例如,假设你有一个20万行的表,你只需要从表中随机100行。这个碎片数是从100/总行数得到:100 / 20万= 0.0005。
该查询将如下所示:SELECT col1 FROM tbl WHERE RAND() <= 0.0005;
为了得到准确的100行结果集,我们可以增加碎片数字和 limit限制:例如
SELECT col1 FROM tbl WHERE RAND()<=0.0006 limit 100;
SELECT col1 FROM tbl ORDER BY RAND() LIMIT 10; 它能很好的运行在小表中。然而,对于大表,生成随机列表行时将产生一个严重的性能问题,MYSQL 需要对每一行进行随机,然后对它们排序。 即使你只想从10W的结果集中取其中随机10行,MySQL也需要对这10W行进行排序并且只提取其中的10行。 为了解决这个问题,我在 WHERE 子句中使用 RAND 并且不使用ORDER BY 子句。首先,你需要计算表中的总行数和你想要的得到随机行数。其次,在 WHERE 子句中加入该碎片数字,并要求结果只能小于(或等于)从这个碎片数字。
例如,假设你有一个20万行的表,你只需要从表中随机100行。这个碎片数是从100/总行数得到:100 / 20万= 0.0005。
该查询将如下所示:SELECT col1 FROM tbl WHERE RAND() <= 0.0005;
为了得到准确的100行结果集,我们可以增加碎片数字和 limit限制:例如
SELECT col1 FROM tbl WHERE RAND()<=0.0006 limit 100;
相关文章推荐
- MySQL如何选择随机记录?
- mysql 如何选择随机行
- 如何选择合适的MySQL存储引擎
- MYSQL字段类型如何选择?
- 如何选择合适的Mysql存储引擎
- mysql随机取数据,如何实现高效率?
- 如何随机取记录?(MSSQL、Access、MySql)
- MySQL 的 utf8_general_ci 和 utf8_unicode_ci 有什么区别,应如何选择?
- 下载时,如何选择低版本的mysql的编译安装包,比如如何下载:mysql-5.7.14.tar.gz
- MySQL基础教程4 —— 数据类型之存储需求及如何选择正确的类型
- MySQL如何选择float, double, decimal
- 从百万级别数据的分析角度,Mysql,Mongodb,Hbase如何选择?
- 如何选择合适的MySQL存储引擎
- Mysql各种存储引擎的特性以及如何选择存储引擎
- MySQL如何选择表类型,MyISAM还是InnoDB?
- 如何选择合适的MySQL存储引擎
- 如何在无穷的数据流随机选择m个数
- MySQL如何选择表类型,MyISAM还是InnoDB?
- 关于mysql存储引擎及如何选择合适的存储引擎