50k 行のデータベースから 100 行をランダムに選択するクエリに問題があります。
最初に関数 RAND() のみを使用しましたが、遅くなりすぎました。
今、私はこのクエリを使用しています:
$query = mysql_query("SELECT t1.* FROM users AS t1 JOIN (SELECT ROUND(RAND() * (SELECT MAX(id) FROM users WHERE picture != '' && age <= 50 && age >= 18 && username != '')) AS id) AS t2 WHERE picture != '' && age <= 50 && age >= 18 && username != '' && t1.id >= t2.id LIMIT 100");
while($q = mysql_fetch_assoc($query))
{ echo $q['id'].'<br>'; }
しかし、空の行がたくさん表示されることがあります。
誰が何がうまくいかないのか教えてもらえますか?
ありがとう!
UPDATE私もこのクエリを試していますが、エラーが発生します。
$query = mysql_query("SELECT id FLOOR(1 + RAND() * x.m_id) 'rand_ind' FROM users (SELECT MAX(t.id) - 1 'm_id' FROM users t) x WHERE picture != '' && age <= 50 && age >= 18 && username != '' ORDER BY rand_ind LIMIT 100");
mysql_fetch_assoc(): 指定された引数は有効な MySQL 結果リソースではありません