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;
このアプローチには以下が含まれます:
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 テーブルからランダムな行を効率的に選択するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。