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  |

现在我想使用 php 按 sq(squence) 的降序在屏幕上显示它们。

我使用了以下代码,但显示错误:

$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

并且一次三个带有链接以向其他人展示。

提前致谢。

4

1 回答 1

1

尝试,

SELECT * FROM posts 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 回答