IT技术博客大学习 共学习 共进步

Mysql的随机读取

淡水河边的博客 2011-06-20 13:34:01 浏览 7,744 次

随机读取数据库记录,搜索发现很多人都使用 order by rand() 来达到该目的,这是mysql提供的功能。但是实际上存在非常严重的性能问题。 如果表里记录不多,偶尔用一下也可以。但是如果数据多的话,就会凸显出查询的性能问题。

随机查询5条记录:

SELECT * FROM `table` ORDER BY RAND() LIMIT 5;

在数十万记录的表里,这样的查询要好几秒的时间。下面采用JOIN的方式改进一下:

SELECT *
FROM `table` AS t1 JOIN (SELECT FLOOR(RAND() * (SELECT MAX(id) FROM `table`)) AS id) AS t2
WHERE t1.id >= t2.id
ORDER BY t1.id ASC LIMIT 5;

这样得到连续的5条记录。要不联续的记录,可以连续查询几次,每次limit 1条。这淡水比较推荐,SQL语句比较清晰,效率也不错。

还有,可以这样的:

SELECT * FROM `table`
WHERE id >= (SELECT FLOOR(RAND() * (SELECT MAX(id) FROM `table`)))  ORDER BY id LIMIT 1;

其他更复杂的实现,淡水无视之。

建议继续学习

  1. HBase随机写以及随机读性能测试 (阅读 7,425)
  2. PHP概率算法(适用于抽奖、随机广告) (阅读 4,423)
  3. 几个随机算法 (阅读 3,522)
  4. PHP伪随机发生器 (阅读 3,245)
  5. 趣题:随机折断的木棒 (阅读 3,143)
  6. 一道随机数题目的求解 (阅读 3,083)