MySQL:未定义的索引,即使它们已定义
我有一些非常简单的代码:
$result = mysql_query("
SELECT max(id) as id, ip, max(entry), COUNT(ip) AS count
FROM table_name
GROUP BY ip
ORDER BY max(id) asc
");
$i = 0;
$num_rows = mysql_num_rows($result);
echo $num_rows;
while($row = mysql_fetch_row($result)) {
$id = $row['id'];
$entry = $row['entry'];
$ip = $row['ip'];
$count = $row['count'];
$i++;
?>
<tr width="100%" align="center">
<td><?php echo $i; ?></td>
<td><?php echo $id; ?></td>
<td><?php echo $entry; ?></td>
<td><?php echo $ip; ?></td>
<td><?php echo $count; ?></td>
<td>
<form style="display:inline;" method="post" action="<?php echo $_SERVER['PHP_SELF']; ?>">
<input type="hidden" value="<?php echo $ip; ?>" name="ip" />
<input type="hidden" value="<?php echo $id; ?>" name="id" />
<input type="submit" value="Ban IP" name="submit" />
</form>
</td>
</tr>
<?php
}
问题是,当我运行它时,我得到:
Notice: Undefined index: id
Notice: Undefined index: entry
Notice: Undefined index: ip
Notice: Undefined index: count
但据我所知,我已经在 SQL 语句中定义了索引,任何帮助将不胜感激。它使用列名 id、ip、entry 选择数据,并为 ip 计数创建索引“count”,那么为什么它说尚未定义呢?
I have some pretty simple code:
$result = mysql_query("
SELECT max(id) as id, ip, max(entry), COUNT(ip) AS count
FROM table_name
GROUP BY ip
ORDER BY max(id) asc
");
$i = 0;
$num_rows = mysql_num_rows($result);
echo $num_rows;
while($row = mysql_fetch_row($result)) {
$id = $row['id'];
$entry = $row['entry'];
$ip = $row['ip'];
$count = $row['count'];
$i++;
?>
<tr width="100%" align="center">
<td><?php echo $i; ?></td>
<td><?php echo $id; ?></td>
<td><?php echo $entry; ?></td>
<td><?php echo $ip; ?></td>
<td><?php echo $count; ?></td>
<td>
<form style="display:inline;" method="post" action="<?php echo $_SERVER['PHP_SELF']; ?>">
<input type="hidden" value="<?php echo $ip; ?>" name="ip" />
<input type="hidden" value="<?php echo $id; ?>" name="id" />
<input type="submit" value="Ban IP" name="submit" />
</form>
</td>
</tr>
<?php
}
The problem is that when I run it, I get:
Notice: Undefined index: id
Notice: Undefined index: entry
Notice: Undefined index: ip
Notice: Undefined index: count
But as far as I can see, I have defined the indexes in the SQL statement, any help would be appreciated. It selects the data using the column names id, ip, entry and creates the index "count" for the count of ip's, so why does it say that it hasn't been defined?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(5)
要将结果行作为关联数组获取,您应该使用
mysql_fetch_assoc< /code>
而不是
mysql_fetch_row
。
此外,尽管您声称已经定义了条目,但您尚未定义
条目
。改变这个:到这个:
To get the result row as an associative array you should use
mysql_fetch_assoc
instead ofmysql_fetch_row
.Also you haven't defined
entry
despite your claim that you have. Change this:To this:
您正在使用 mysql_fetch_row(),它将数据作为索引数组返回。您需要
mysql_fetch_assoc()
来代替。You're using
mysql_fetch_row()
, which returns the data as an indexed array. You wantmysql_fetch_assoc()
instead.mysql_fetch_row
返回一个枚举数组。您需要
mysql_fetch_array
。或者,您可以按列索引获取值:
mysql_fetch_row
returns an enumerated array.You want
mysql_fetch_array
.Alternatively you could fetch values by column index:
只需尝试 mysql_fetch_assoc 即可。
Just try mysql_fetch_assoc instead.
您需要
mysql_fetch_assoc
,mysql_fetch_row
返回一个带有数字索引的普通数组。You need
mysql_fetch_assoc
,mysql_fetch_row
returns a plain array with numerical indexes.