從大型資料庫表中選擇隨機行可能具有挑戰性。隨著表格變大,通常建議的 ORDER BY RAND() 方法面臨可擴展性問題。
替代方法
一種更具可擴展性的方法涉及利用 MySQL 的本機變數操作和查詢串聯能力。以下是一個範例:
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;
此技術計算表內的隨機偏移量,並使用它來有效地檢索單行。
PHP 實作
如果您喜歡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(); ?>
透過利用這些技術,您可以有效地從大型MySQL 表中檢索隨機行,而不會影響效能。
以上是如何有效率地從大型 MySQL 表中檢索隨機行?的詳細內容。更多資訊請關注PHP中文網其他相關文章!