MySQL如何選擇隨機記錄?有好幾種方式呢!

在本教程中,您將學習從MySQL的數據庫表中選擇隨機記錄的各種技術方法。有時我們需要從表中選擇隨機記錄,例如:- 在博客中選擇一些隨機帖子,并在側欄中顯示。- 在“每日報價”窗口小部件中顯示隨機報價。- 在圖庫中選擇隨機圖片,并作為特色圖片。## MySQL使用ORDER BY RAND()選擇隨機記錄MySQL沒有內置語句來從數據庫表中選擇隨機記錄。為了實現這個目的,可使用RAND函數。 以下查詢是從數據庫表中選擇一個隨機記錄:sqlSELECT *FROM tblORDER BY RAND()LIMIT 1;讓我們詳細地看看上面的查詢語句。- RAND()函數為表中的每一行生成一個隨機值。- ORDER BY子句按照RAND()函數生成的隨機數對表中的所有行進行排序。- LIMIT子句選擇隨機排序的結果集中的第一行。如果要從數據庫表中選擇N個隨機記錄,則需要修改LIMIT子句后指定的值,如下所示:sqlSELECT *FROM tableORDER BY RAND()LIMIT N;例如,要在customer表中選擇5個隨機客戶,請使用以下查詢:sqlSELECT t.customer_id, t.customer_nameFROM studymysql.customer AS tORDER BY RAND()LIMIT 5;執行上面的查詢語句,得到以下結果(每次執行結果都不太一樣) -

> 您可能會得到一個不同的結果數據,因為它是隨機的。這種技術非常適合小表。如果在大的表上執行速度是非常緩慢的,因為MySQL必須排序整個表,以挑選隨機的行數據。查詢的速度還取決于表中的行數。表具有的行越多,MySQL都要為每行生成隨機數,所以所需的時間就越多。## MySQL使用INNER JOIN子句選擇隨機記錄此技術方法要求選擇隨機記錄的表要具有自動增長主鍵字段,并且序列的值是連續沒有間隙的。以下查詢是基于主鍵列生成一個隨機數:sqlSELECT ROUND(RAND() * ( SELECT MAX(id) FROM table)) as id;我們可以使用上面查詢返回的結果集來連接表,如下所示:sqlSELECT t.*FROM table AS t JOIN (SELECT ROUND(RAND() * (SELECT MAX(id) FROM table )) AS id ) AS xWHERE t.id >= x.idLIMIT 1;使用此技術方法,需要多次執行查詢以獲取多個隨機行,因為如果增加返回行數限制,查詢將只提供從隨機選擇的行開始的順序行。以下查詢是從customer表中返回一個隨機客戶。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;執行上面的查詢語句,得到以下結果 -
## MySQL使用變量選擇隨機記錄在這種情況下,表的id列的值落在1...N的范圍內,并且在該范圍內的值連續沒有間隙,可以使用以下技術:- 首先,在1..N范圍內選擇隨機數。- 第二步,根據隨機數選擇行記錄。以下語句可幫助您完成此操作: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;請注意,用戶定義的變量是特定于連接的。所以這種技術方法不能用于連接池。此外,主鍵必須是整數類型,其值必須在值是連續沒有間隙的序列中。在本教程中,我們展示了幾種從表中選擇隨機記錄的技術方法。StudyMySQL官方QQ群(2): 41840707 歡迎各位MySQL學習和用戶加入。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容