在本教程中,您將學(xué)習(xí)從MySQL的數(shù)據(jù)庫(kù)表中選擇隨機(jī)記錄的各種技術(shù)方法。有時(shí)我們需要從表中選擇隨機(jī)記錄,例如:- 在博客中選擇一些隨機(jī)帖子,并在側(cè)欄中顯示。- 在“每日?qǐng)?bào)價(jià)”窗口小部件中顯示隨機(jī)報(bào)價(jià)。- 在圖庫(kù)中選擇隨機(jī)圖片,并作為特色圖片。## MySQL使用ORDER BY RAND()選擇隨機(jī)記錄MySQL沒(méi)有內(nèi)置語(yǔ)句來(lái)從數(shù)據(jù)庫(kù)表中選擇隨機(jī)記錄。為了實(shí)現(xiàn)這個(gè)目的,可使用RAND
函數(shù)。 以下查詢是從數(shù)據(jù)庫(kù)表中選擇一個(gè)隨機(jī)記錄:sqlSELECT *FROM tblORDER BY RAND()LIMIT 1;
讓我們?cè)敿?xì)地看看上面的查詢語(yǔ)句。- RAND()
函數(shù)為表中的每一行生成一個(gè)隨機(jī)值。- ORDER BY子句按照RAND()
函數(shù)生成的隨機(jī)數(shù)對(duì)表中的所有行進(jìn)行排序。- LIMIT子句選擇隨機(jī)排序的結(jié)果集中的第一行。如果要從數(shù)據(jù)庫(kù)表中選擇N
個(gè)隨機(jī)記錄,則需要修改LIMIT
子句后指定的值,如下所示:sqlSELECT *FROM tableORDER BY RAND()LIMIT N;
例如,要在customer
表中選擇5
個(gè)隨機(jī)客戶,請(qǐng)使用以下查詢:sqlSELECT t.customer_id, t.customer_nameFROM studymysql.customer AS tORDER BY RAND()LIMIT 5;
執(zhí)行上面的查詢語(yǔ)句,得到以下結(jié)果(每次執(zhí)行結(jié)果都不太一樣) -
sqlSELECT ROUND(RAND() * ( SELECT MAX(id) FROM table)) as id;
我們可以使用上面查詢返回的結(jié)果集來(lái)連接表,如下所示:sqlSELECT t.*FROM table AS t JOIN (SELECT ROUND(RAND() * (SELECT MAX(id) FROM table )) AS id ) AS xWHERE t.id >= x.idLIMIT 1;
使用此技術(shù)方法,需要多次執(zhí)行查詢以獲取多個(gè)隨機(jī)行,因?yàn)槿绻黾臃祷匦袛?shù)限制,查詢將只提供從隨機(jī)選擇的行開(kāi)始的順序行。以下查詢是從customer
表中返回一個(gè)隨機(jī)客戶。sqlSELECT t.customer_id, t.customer_nameFROM studymysql.customer AS t JOIN (SELECT ROUND(RAND() * (SELECT MAX(customer_id) FROM studymysql.customer)) AS customer_id ) AS xWHERE t.customer_id >= x.customer_idLIMIT 1;
執(zhí)行上面的查詢語(yǔ)句,得到以下結(jié)果 - id
列的值落在1...N
的范圍內(nèi),并且在該范圍內(nèi)的值連續(xù)沒(méi)有間隙,可以使用以下技術(shù):- 首先,在1..N
范圍內(nèi)選擇隨機(jī)數(shù)。- 第二步,根據(jù)隨機(jī)數(shù)選擇行記錄。以下語(yǔ)句可幫助您完成此操作:sqlSELECT table. *FROM (SELECT ROUND(RAND() * (SELECT MAX(id) FROM table)) random_num, @num:=@num + 1 FROM (SELECT @num:=0) AS a, table LIMIT N) AS b, table AS tWHERE b.random_num = t.id;
請(qǐng)注意,用戶定義的變量是特定于連接的。所以這種技術(shù)方法不能用于連接池。此外,主鍵必須是整數(shù)類(lèi)型,其值必須在值是連續(xù)沒(méi)有間隙的序列中。在本教程中,我們展示了幾種從表中選擇隨機(jī)記錄的技術(shù)方法。StudyMySQL官方QQ群(2): 41840707 歡迎各位MySQL學(xué)習(xí)和用戶加入。