1

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 結果リソースではありません

4

3 に答える 3

1

RAND() で順序をランダム化し、制限 0,100 を選択するだけです

order by rand() limit 0,100

mysqlでそれを行う最速の方法

代替案としてこれを読むことをお勧めしますhttp://jan.kneschke.de/projects/mysql/order-by-rand/ その記事で提案されている方法でそれを行うにはいくつかの制限があります

于 2013-05-31T08:27:32.180 に答える
1

テーブル内の ID が連続している場合は、0 から "max_rows" までの x 乱数を生成してみませんか。

次に、次のようなことを行います

'SELECT ... FROM .... WHEREIDin (' . implode(',', $randomNumbers) . ')';

生成された ID を持つ行が返されます。

于 2013-05-31T08:33:34.760 に答える
-1

使用できます:

SELECT ... FROM ... LIMIT $rand,100

$randコード側から生成された乱数 (0 ~ 50k) はどこにありますか

于 2013-05-31T08:26:26.737 に答える