MySQL でのランダムな選択と順序付け
MySQL データベースにクエリを実行する場合、レコードのサブセットをランダムに選択することが一般的です。これを実現するには、ORDER BY RAND() 句を使用できます。ただし、この句を他の順序句と組み合わせる場合は、操作の順序を考慮することが重要です。
レコードのランダムなサブセットを選択し、結果のセットを別の列で並べ替えようとすると、よくある落とし穴が 1 つ発生します。次のクエリはその例です。
SELECT * FROM users WHERE 1 ORDER BY RAND(), name ASC LIMIT 20
このクエリの目的は、users テーブルから 20 人のランダムなユーザーを選択し、名前列で昇順に並べ替えることです。ただし、このクエリでは望ましい結果は得られません。
その理由は、ORDER BY RAND() 句が非決定的な順序付けを導入しているためです。これは、クエリが実行されるたびに結果の順序が変わることを意味します。その結果、後続の名前 ASC 句を使用して結果を確実に並べ替えることはできません。
結果を正しく並べ替えるには、サブクエリを使用する必要があります。次のクエリは 20 人のユーザーをランダムに選択し、名前列で並べ替えます。
SELECT * FROM ( SELECT * FROM users ORDER BY RAND() LIMIT 20 ) T1 ORDER BY name
内部クエリは 20 人のユーザーをランダムに選択し、結果を一時テーブル T1 に保存します。次に、外側のクエリは T1 からすべての行を選択し、名前順に並べます。
以上がMySQL でランダムなサブセットを選択し、別の列で並べ替えるにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。