最近工作中遇到一个需求是定时查询用户表,并随机获取其中的一条信息,因为刚从oracle转MySQL,对mysql没那么熟悉,所以上完检索了一下,大概有几种方案:
方法一、最原始,最直观的语法
SELECT * FROM tableName ORDER BY RAND() LIMIT 1
不过这种方式极不推荐,因为试过,查询效率极低
方法二、(花费时间 0.147433 秒 )
SELECT * FROM `table`
WHERE id >= (SELECT floor( RAND() * ((SELECT MAX(id) FROM `table`)-(SELECT MIN(id) FROM `table`)) + (SELECT MIN(id) FROM `table`)))
ORDER BY id LIMIT 1;
方法三、(花费时间 0.015130 秒 )
SELECT *
FROM `table` AS t1 JOIN (SELECT ROUND(RAND() * ((SELECT MAX(id) FROM `table`)-(SELECT MIN(id) FROM `table`))+(SELECT MIN(id) FROM `table`)) AS id) AS t2
WHERE t1.id >= t2.id
ORDER BY t1.id LIMIT 1;
总结:方式二和方式三都是效率很高的,不过通过对比,明显方式三更胜一筹,看来采用JOIN的语法比直接在WHERE中使用函数效率还要高很多