不能显示,是什么原因???????????????????

luyinhu 2008-12-21 05:07:21

while ($arrRow = mysql_fetch_row ($result))
{
?>
<tr>
<td height='20' align='center' bgcolor='#FFFFFF'><?php echo $arrRow[0];?></td>
<td align='center' bgcolor='#FFFFFF'><a href='shangpin.php?lb=<?php echo $arrRow[lbid];?>'><?php echo $arrRow[lbid];?></a></td>
<td bgcolor='#FFFFFF'><a href='../Merchandise.php?id=<?php echo $arrRow[id];?>'><?php echo $arrRow[biaoti];?></a></td>
<td align='center' bgcolor='#FFFFFF'><a href='shangpin_gl.php'>编辑</a></td>
<td align='center' bgcolor='#FFFFFF'><a href='?id=&mod=del'>删除</a></td>
</tr>
</TABLE>
<?php
}
?>




<?php echo $arrRow[0];?>为什么这么写可以显示结果

<?php echo $arrRow[id];?>这么写就不行呢?
...全文
281 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
hzcenter 2008-12-21
  • 打赏
  • 举报
回复
mysql_fetch_array
(PHP 3, PHP 4 , PHP 5)

mysql_fetch_array -- 从结果集中取得一行作为关联数组,或数字数组,或二者兼有
说明
array mysql_fetch_array ( resource result [, int result_type])


返回根据从结果集取得的行生成的数组,如果没有更多行则返回 FALSE。

mysql_fetch_array() 是 mysql_fetch_row() 的扩展版本。除了将数据以数字索引方式储存在数组中之外,还可以将数据作为关联索引储存,用字段名作为键名。

如果结果中的两个或以上的列具有相同字段名,最后一列将优先。要访问同名的其它列,必须用该列的数字索引或给该列起个别名。对有别名的列,不能再用原来的列名访问其内容(本例中的 'field')。 例子 1. 相同字段名的查询

select table1.field as foo, table2.field as bar from table1, table2




有一点很重要必须指出,用 mysql_fetch_array() 并不明显 比用 mysql_fetch_row() 慢,而且还提供了明显更多的值。

mysql_fetch_array() 中可选的第二个参数 result_type 是一个常量,可以接受以下值:MYSQL_ASSOC,MYSQL_NUM 和 MYSQL_BOTH。本特性是 PHP 3.0.7 起新加的。本参数的默认值是 MYSQL_BOTH。

如果用了 MYSQL_BOTH,将得到一个同时包含关联和数字索引的数组。用 MYSQL_ASSOC 只得到关联索引(如同 mysql_fetch_assoc() 那样),用 MYSQL_NUM 只得到数字索引(如同 mysql_fetch_row() 那样)。

注: 该函数返回的字段名是大小写敏感的。

例子 2. mysql_fetch_array 使用 MYSQL_NUM

<?php
mysql_connect("localhost", "mysql_user", "mysql_password") or
die("Could not connect: " . mysql_error());
mysql_select_db("mydb");

$result = mysql_query("SELECT id, name FROM mytable");

while ($row = mysql_fetch_array($result, MYSQL_NUM)) {
printf ("ID: %s Name: %s", $row[0], $row[1]);
}

mysql_free_result($result);
?>



例子 3. mysql_fetch_array 使用 MYSQL_ASSOC

<?php
mysql_connect("localhost", "mysql_user", "mysql_password") or
die("Could not connect: " . mysql_error());
mysql_select_db("mydb");

$result = mysql_query("SELECT id, name FROM mytable");

while ($row = mysql_fetch_array($result, MYSQL_ASSOC)) {
printf ("ID: %s Name: %s", $row["id"], $row["name"]);
}

mysql_free_result($result);
?>



例子 4. mysql_fetch_array 使用 MYSQL_BOTH

<?php
mysql_connect("localhost", "mysql_user", "mysql_password") or
die("Could not connect: " . mysql_error());
mysql_select_db("mydb");

$result = mysql_query("SELECT id, name FROM mytable");

while ($row = mysql_fetch_array($result, MYSQL_BOTH)) {
printf ("ID: %s Name: %s", $row[0], $row["name"]);
}

mysql_free_result($result);
?>



参见 mysql_fetch_row() 和 mysql_fetch_assoc()。
海诗美妆 2008-12-21
  • 打赏
  • 举报
回复
mysql_fetch_row就是返回一个$arrRow[0]这种数组,
要达到你的效果,得用mysql_fetch_assoc
<?php

$conn = mysql_connect("localhost", "mysql_user", "mysql_password");

if (!$conn) {
echo "Unable to connect to DB: " . mysql_error();
exit;
}

if (!mysql_select_db("mydbname")) {
echo "Unable to select mydbname: " . mysql_error();
exit;
}

$sql = "SELECT id as userid, fullname, userstatus
FROM sometable
WHERE userstatus = 1";

$result = mysql_query($sql);

if (!$result) {
echo "Could not successfully run query ($sql) from DB: " . mysql_error();
exit;
}

if (mysql_num_rows($result) == 0) {
echo "No rows found, nothing to print so am exiting";
exit;
}

while ($row = mysql_fetch_assoc($result)) {
echo $row["userid"];
echo $row["fullname"];
echo $row["userstatus"];
}

mysql_free_result($result);

?>
luyinhu 2008-12-21
  • 打赏
  • 举报
回复
这个什么原因啊?
是不是服务器的问题?
luyinhu 2008-12-21
  • 打赏
  • 举报
回复
谢谢,
为什么还是不行?
gbgaobo5t 2008-12-21
  • 打赏
  • 举报
回复
这么写就OK了<?php echo $arrRow['id'];?>

21,886

社区成员

发帖
与我相关
我的任务
社区描述
从PHP安装配置,PHP入门,PHP基础到PHP应用
社区管理员
  • 基础编程社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧