使用MySQL 選擇隨機行:詳細解決方案
經常出現的問題是如何從大型MySQL 表中有效地選擇隨機行,而無需求助於ORDER BY RAND() 方法,眾所周知,該方法對於較大的資料集效率較低。為了因應這個挑戰,讓我們來探索一個可行的解決方案:
基於MySQL 的方法:
利用以下SQL 語句的組合:
SET @r := (SELECT FLOOR(RAND() * (SELECT COUNT(*) FROM mytable))); SET @sql := CONCAT('SELECT * FROM mytable LIMIT 1 OFFSET ', @r); PREPARE stmt1 FROM @sql; EXECUTE stmt1;
利用以下SQL 語句的組合:
準備並執行構造的查詢。
基於PHP 的方法:
<?php $mysqli->begin_transaction(); $result = $mysqli->query("SELECT COUNT(*) FROM mytable"); $row = $result->fetch_row(); $count = $row[0]; $offset = mt_rand(0, $count); $result = $mysqli->query("SELECT * FROM mytable LIMIT 1 OFFSET $offset"); ... $mysqli->commit();
如果您喜歡工作使用PHP,您可以使用以下程式碼片段:
以上是如何從大型 MySQL 表中有效地選擇隨機行?的詳細內容。更多資訊請關注PHP中文網其他相關文章!