Zufällige Zeilen mit MySQL auswählen: Eine detaillierte Lösung
Häufig stellt sich die Frage, wie man zufällige Zeilen aus einer großen MySQL-Tabelle ohne effektiv auswählen kann Rückgriff auf die Methode ORDER BY RAND(), die für größere Datensätze bekanntermaßen ineffizient ist. Um dieser Herausforderung zu begegnen, erkunden wir eine praktikable Lösung:
MySQL-basierter Ansatz:
Verwenden Sie die Kombination der folgenden SQL-Anweisungen:
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;
Dieser Ansatz beinhaltet:
PHP-basierter Ansatz:
Wenn Sie lieber mit PHP arbeiten möchten, können Sie den folgenden Code verwenden Snippet:
<?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();
Dieser Ansatz beinhaltet:
Das obige ist der detaillierte Inhalt vonWie wählt man effizient zufällige Zeilen aus einer großen MySQL-Tabelle aus?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!