溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

mysql如何隨機(jī)獲取幾條數(shù)據(jù)

發(fā)布時(shí)間:2022-01-06 13:12:58 來(lái)源:億速云 閱讀:1411 作者:柒染 欄目:編程語(yǔ)言

mysql如何隨機(jī)獲取幾條數(shù)據(jù),很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來(lái)學(xué)習(xí)下,希望你能有所收獲。

mysql隨機(jī)獲取幾條數(shù)據(jù)的方法:1、通過(guò)“SELECT * FROM tablename ORDER BY RAND() LIMIT”獲取數(shù)據(jù);2、通過(guò)“ORDER BY t1.id ASC LIMIT”方式獲取指定條數(shù)的數(shù)據(jù)等。

本文操作環(huán)境:Windows7系統(tǒng)、PHP7.1版、Dell G3電腦。

mysql怎么隨機(jī)獲取幾條數(shù)據(jù)?

mysql實(shí)現(xiàn)隨機(jī)獲取幾條數(shù)據(jù)的方法

sql語(yǔ)句有幾種寫法:

1:SELECT * FROM tablename ORDER BY RAND() LIMIT 想要獲取的數(shù)據(jù)條數(shù);

2:SELECT *FROM `table` WHERE id >= (SELECT FLOOR( MAX(id) * RAND()) FROM `table` ) ORDER BY id LIMIT 想要獲取的數(shù)據(jù)條數(shù);

3: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 想要獲取的數(shù)據(jù)條數(shù);

4:SELECT * FROM `table`WHERE id >= (SELECT floor(RAND() * (SELECT MAX(id) FROM `table`))) ORDER BY id LIMIT 想要獲取的數(shù)據(jù)條數(shù);

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 想要獲取的數(shù)據(jù)條數(shù);

6: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 想要獲取的數(shù)據(jù)條數(shù);

反饋:

實(shí)測(cè) 38萬(wàn)數(shù)據(jù),隨機(jī)取10條 1 可以隨機(jī)取值,執(zhí)行時(shí)間1-2秒。 2 運(yùn)行超過(guò)20秒沒反應(yīng),試了3次。 3 取的10條數(shù)據(jù)是連續(xù)的ID,執(zhí)行0.001秒。 4 隨機(jī)取10條,id在1-4000之間,執(zhí)行0.003秒,試了10次以上。 5 隨機(jī)取10條,id在1-4000之間,執(zhí)行0.003秒,試了10次以上。 6 取的10條數(shù)據(jù)是連續(xù)的ID,執(zhí)行0.001秒。

看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝您對(duì)億速云的支持。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI