0

次のようなmysqlのテーブルがあります:

| sq | date | title | description |
-----------------------------------
| 10 | 10-06| xxxx  |  blah blah  |
| 09 | 10-06| xxxx  |  blah blah  |
| 08 | 10-06| xxxx  |  blah blah  |
| 07 | 10-06| xxxx  |  blah blah  |

今私はsq(squence)の降順でphpを使って画面に表示したい。

次のコードを使用しましたが、エラーが表示されます。

$result = mysql_query("SELECT * FROM posts WHERE (SELECT MAX(sn) FROM posts)");

echo('<ul class="news">');
while($row=mysql_fetch_array($result)) {
    $date=$row["date"];
    $title=$row["title"];
    $description=$row["description"];
    echo "<li><strong>$date</strong><h4><a href='#'>$lastname</a></h4>$description</li>";
}
echo('</ul>');

エラーメッセージ:

Warning: mysql_fetch_array() expects parameter 1 to be resource, boolean given in C:\wamp\www\final\index.php on line 99
Call Stack

一度に 3 つずつ、他のユーザーを表示するためのリンクが表示されます。

前もって感謝します。

4

1 に答える 1

1

試す、

SELECT * FROM 投稿 ORDER BY sq DESC

結果を制限したい場合は、これを使用して10行としましょう

SELECT * FROM posts ORDER BY sq DESC LIMIT 10

編集: RE: mysql_fetch_array() は、パラメーター 1 がリソースであると想定しています

このエラーは、

$result = mysql_query("SELECT * FROM posts WHERE (SELECT MAX(sn) FROM posts)");

ステートメントが失敗しました。つまり、クエリが間違っています

MySQL がクエリの実行に失敗すると、リソース ハンドルの代わりにFALSE返されます。$result

@vidyaが言うように、ステートメントの$result後に常にテストをコーディングする必要がありますmysql_query()

$result = mysql_query("SELECT * FROM posts WHERE (SELECT MAX(sn) FROM posts)");
if ( ! $result ) {
    die( mysql_errno() . ' ' . mysql_error() );
}
于 2013-07-01T11:16:33.997 に答える