Das Auswählen zufälliger Zeilen aus einer großen Datenbanktabelle kann eine Herausforderung sein. Der häufig vorgeschlagene ORDER BY RAND()-Ansatz weist Skalierbarkeitsprobleme auf, wenn die Tabelle größer wird.
Alternativer Ansatz
Eine skalierbarere Methode beinhaltet die Verwendung der nativen Variablenmanipulation und -abfrage von MySQL Verkettungsmöglichkeiten. Hier ist ein Beispiel:
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;
Diese Technik berechnet einen zufälligen Offset innerhalb der Tabelle und verwendet ihn, um eine einzelne Zeile effizient abzurufen.
PHP-Implementierung
Wenn Sie PHP bevorzugen, können Sie einen ähnlichen Ansatz wie folgt implementieren (ungetestet):
<?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(); ?>
Indem Sie diese nutzen Techniken können Sie effektiv zufällige Zeilen aus großen MySQL-Tabellen abrufen, ohne die Leistung zu beeinträchtigen.
Das obige ist der detaillierte Inhalt vonWie kann ich zufällige Zeilen effizient aus einer großen MySQL-Tabelle abrufen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!