基本上我的数据库中有文章,我想改变第一条记录的显示方式。我希望最新(已发布)文章成为焦点,而较旧的文章仅列出,(请参阅F1.com)。我需要知道如何在数组中获取我的第一个值并让它以不同的方式显示,但我不确定如何执行此操作,我可以这样做,以便所有行显示相同,而不是如何更改第一行。我还需要知道如何告诉其余的行在之后显示相同的内容,我猜你在那里使用了 if 语句,并且在此之前对行进行了某种计数。
当前代码:
$result = mysql_query("SELECT * FROM dbArticle WHERE userID='".$_SESSION["**"]."' ORDER BY timestamp DESC");
while($row = mysql_fetch_array($result))
{
echo "<h2 class=\"heading1\">". $row['title'] ."</h2>";
echo "By: ".$row['username']." Type: ".$row['type']." Posted: ".$row['timestamp']."
$body = $row['body'];
echo "<br/><p>";
echo substr("$body",0,260);
echo "...<span class=\"tool\"><a class=\"blue\" href=\"index.php?pageContent=readArticle&id=".$row['id']."\">Read More</a></span></p><hr/>";
}
mysql_close($con);
好的,我采用了 Luke Dennis 的代码并尝试对其进行测试,但我收到此错误:警告:为 foreach() 提供的参数无效,这是 foreach 语句的行。刚刚想到的是,我只希望显示 5 篇左右的旧文章。这就是我创建错误的原因:
<? $con = mysql_connect("localhost","****","***");
if (!$con)
{
die('Could not connect: ' . mysql_error());
}
mysql_select_db("******", $con);
$result = mysql_query("SELECT * FROM dbArticle ORDER BY timestamp DESC");
$first = true;
foreach($result as $row){
if($first)
{
echo"".$row['title']."";
echo"this is the headline";
$first = false;
}
else
{
echo"".$row['title']."";
}
}
?>
我需要在某处添加 mysql_fetch_array 来设置数组吗?