但是,后來我查了一下MYSQL的官方手冊,里面針對RAND()的提示大概意思就是,在ORDER BY從句里面不能使用RAND()函數,因為這樣會導致數據列被多次掃描。但是在MYSQL 3.23版本中,仍然可以通過ORDER BY RAND()來實現隨機。 測試一下才發現這樣效率非常低。一個15萬余條的庫,查詢5條數據,居然要8秒以上。查看官方手冊,也說rand()放在ORDER BY 子句中會被執行多次,自然效率及很低。 You cannot use a column with RAND() values in an ORDER BY clause, because ORDER BY would evaluate the column multiple times. 搜索Google,網上基本上都是查詢max(id) * rand()來隨機獲取數據。
復制代碼 代碼如下:
SELECT * FROM 'table' AS t1 JOIN (SELECT ROUND(RAND() * (SELECT MAX(id) FROM 'table')) AS id) AS t2 WHERE t1.id >= t2.id ORDER BY t1.id ASC LIMIT 5;
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;
SELECT * FROM 'table' AS t1 JOIN ( SELECT ROUND( # 最小值 + (1 至 最小與最大值差) RAND() * ( (SELECT MAX(id) FROM 'table')-(SELECT MIN(id) FROM 'table') )