インターネットで乱数ステートメントを見つけて、自分のニーズと組み合わせて実行しましたが、間違っていました。
長い間調べましたが、間違いが見つかりませんでした。アドバイスをお願いします。
ディスカッションに返信(解決策)
$str="select * from dizhi where shijiancuo>'$times' GROUP BY user HAVING COUNT(user) > 4 AS t1 JOIN (SELECT ROUND(RAND() * (SELECT MAX(id) FROM dizhi)) AS id) AS t2 WHERE t1.id >= t2.id ORDER BY t1.id ASC LIMIT 1" ;
23 コードは次のとおりです
Warning: mysql_num_rows(): supplied argument is not a valid MySQL result resource in D:\www\AppServ\www\tuijianshuchu.php on line 23
SQL ステートメントが間違っているので、$str ステートメントを出力して、それが何であるかを確認してください
$result=mysql_query($str , $con) または die(mysql_error());
$result=mysql_query($str, $con); //送出查? $rows=mysql_num_rows($result); //23行
select * from
(select * from dizhi where shijiancuo>'$times' GROUP BY user HAVING COUNT(user) > 4) AS t1
J OIN ( SELECT ROUND(RAND() * (SELECT MAX(id) FROM dizhi)) AS id) AS t2
WHERE t1.id >= t2.id
ORDER BY t1.id ASC LIMIT 1
JOIN (SELECT ROUND (RAND () * (SELECT MAX(id) FROM dizhi)) AS id from dizhi) AS t2
この文の意味が全く分かりませんでした
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'AS t1 JOIN (SELECT ROUND(RAND() * (SELECT MAX(id) FROM dizhi)) AS id) AS t2 ' at line 1
インターネットでは ROUND 関数について話題になっています 数値フィールドを指定された小数点以下の桁数に四捨五入するために使用されるため、このステートメントの結果がよくわかりません
RAND は 1 未満の乱数を生成します
SELECT MAX(id) FROM dizhiテーブル dizhi 内の最大の ID 値を取得します
このクエリ コマンドの意味は次のとおりです:
テーブル内の任意の ID 値を取得します
わかりました、3Q。