IT技术博客大学习 共学习 共进步
全部 移动开发 后端 数据库 AI 算法 安全 DevOps 前端 设计 开发者

Mysql中rand()的实现方式

Incessant 2009-10-11 22:35:22 累计浏览 2,700 次
本机暂存
mysql> use test;

    Database changed

    mysql> select count(*) from test;

    +----------+

    | count(*) |

    +----------+

    | 2097152 |

    +----------+

    1 row in set (0.00 sec)

mysql> select * from test ORDER BY RAND() LIMIT 1;

    +--------+------+

    | a | b |

    +--------+------+

    | 765909 | |

    +--------+------+

    1 row in set (8.78 sec) --用了将近9s

引Mysql文档:

    You cannot use a column with RAND() values in an ORDER BY clause, because ORDER BY would evaluate the column multiple times.也就是 order by rand()会去扫描多次,造成性能的下降。

看看下面的实现方式:

    先取这个表的最大值*rand(),取出这个随机值后,在进行比对。

    mysql> select * from test

     -> where a >= (select floor(rand() * (select max(a) from test))) order by a limit 1;

    +-------+------+

    | a | b |

    +-------+------+

    | 99275 | |

    +-------+------+

    1 row in set (0.00 sec) --在0.00s左右

实际上很多实现方式稍微改一改,带来的性能是很可观的。

同分类推荐文章

  1. 使用deepseek进行Oracle恢复,引起重大故障 (2026-06-22 10:56:00)
  2. 接手一个只差临门一脚的数据库恢复 (2026-06-18 00:13:09)
  3. 我做了一个 AI 版的 StarRocks 升级风险扫描工具,直接帮我定位到一个风险 (2026-06-15 01:00:00)

查看更多 数据库 文章 →

建议继续学习

  1. 用Hyer来进行网站的抓取 (累计阅读 158,251)
  2. MySQL数据库在实际应用一些方面的介绍 (累计阅读 36,397)
  3. WordPress插件开发 -- 在插件使用数据库存储数据 (累计阅读 29,164)
  4. Mysql监控指南 (累计阅读 21,351)
  5. 由浅入深探究mysql索引结构原理、性能分析与优化 (累计阅读 16,523)
  6. 如何查找消耗资源较大的SQL (累计阅读 15,210)
  7. 在Apache2.2.XX下安装Mod-myvhost模块 (累计阅读 13,057)
  8. 15个最好的免费开源电子商务平台 (累计阅读 12,541)
  9. 浅谈MySQL索引背后的数据结构及算法 (累计阅读 11,904)
  10. 整理了一份招PHP高级工程师的面试题 (累计阅读 11,708)