如何在MySQL中有效地选择随机记录?

前端之家收集整理的这篇文章主要介绍了如何在MySQL中有效地选择随机记录?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

  1. MysqL> EXPLAIN SELECT * FROM urls ORDER BY RAND() LIMIT 1;
  2. +----+-------------+-------+------+---------------+------+---------+------+-------+---------------------------------+
  3. | id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
  4. +----+-------------+-------+------+---------------+------+---------+------+-------+---------------------------------+
  5. | 1 | SIMPLE | urls | ALL | NULL | NULL | NULL | NULL | 62228 | Using temporary; Using filesort |
  6. +----+-------------+-------+------+---------------+------+---------+------+-------+---------------------------------+

以上不符合效率,我该如何正确地做到?

UPDATE

似乎使用答案中提到的解决方案仍无济于事:

  1. MysqL> explain SELECT *
  2. -> FROM (
  3. -> SELECT @cnt := COUNT(*) + 1,-> @lim := 10
  4. -> FROM urls
  5. -> ) vars
  6. -> STRAIGHT_JOIN
  7. -> (
  8. -> SELECT r.*,-> @lim := @lim - 1
  9. -> FROM urls r
  10. -> WHERE (@cnt := @cnt - 1)
  11. -> AND RAND(20090301) < @lim / @cnt
  12. -> ) i;
  13. +----+-------------+------------+--------+---------------+------+---------+------+-------+------------------------------+
  14. | id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
  15. +----+-------------+------------+--------+---------------+------+---------+------+-------+------------------------------+
  16. | 1 | PRIMARY |
最佳答案
Quassnoi编写了一个关于随机选择行而不执行排序的post.他的示例随机选择10行,但您可以调整它以仅选择一行.

如果你想要它真的很快,那么你可以使用一个不完全统一的近似值,或者有时候无法返回一行.

您还可以使用存储过程从Bill Karwin’s post快速选择随机行:

  1. SET @r := (SELECT ROUND(RAND() * (SELECT COUNT(*) FROM mytable)));
  2. SET @sql := CONCAT('SELECT * FROM mytable LIMIT ',@r,',1');
  3. PREPARE stmt1 FROM @sql;
  4. EXECUTE stmt1;

请注意,这将在MyISAM中比InnoDB运行得快得多,因为在InnoDB中COUNT(*)是昂贵的,但在MyISAM中几乎是即时的.

猜你在找的MySQL相关文章