MySQL下的RAND()优化案例分析

2019-01-05 09:54:11丽君
[yejr@imysql]> select id from t_innodb_random t1 join (select rand() * (select max(id) from t_innodb_random) as nid) t2 on t1.id > t2.nid limit 1000G 1000 rows in set (0.00 sec)

可以看到,全索引检索,发现符合记录的条件后,直接取得1000行,这个方法是最快的。

综上,想从MySQL数据库中随机取一条或者N条记录时,最好把RAND()生成随机数放在JOIN子查询中以提高效率。
上面说了那么多的废话,最后简单说下,就是把下面这个SQL:

SELECT id FROM table ORDER BY RAND() LIMIT n;

改造成下面这个:

SELECT id FROM table t1 JOIN (SELECT RAND() * (SELECT MAX(id) FROM table) AS nid) t2 ON t1.id > t2.nid LIMIT n;

如果想要达到完全随机,还可以改成下面这种写法:

SELECT id FROM table t1 JOIN (SELECT round(RAND() * (SELECT MAX(id) FROM table)) AS nid FROM table LIMIT n) t2 ON t1.id = t2.nid;

就可以享受在SQL中直接取得随机数了,不用再在程序中构造一串随机数去检索了。

您可能感兴趣的文章:

MySQL的指定范围随机数函数rand()的使用技巧mysql 某字段插入随机数(插入随机数到MySQL数据库)MySQL查询随机数据的4种方法和性能对比mysql获取随机数据的方法mysql优化取随机数据慢的方法MySQL取出随机数据从MySQL数据库表中取出随机数据的代码MySQL中的RAND()函数使用详解MySQL优化之对RAND()的优化方法MySQL Order By Rand()效率分析mysql中RAND()随便查询记录效率问题和解决办法分享MYSQL随机抽取查询 MySQL Order By Rand()效率问题php 随机记录mysql rand()造成CPU 100%的解决办法MySQL rand函数实现随机数的方法