我正在尝试打印json_encode,我得到输出重复。我确信数据库中只有一条记录,但它以各种格式显示两次相同的记录数据。就是这样:
[{"0":"Polo","name":"Polo","1":"City ","location":"City ","2":"Manama","city":"Manama"}]
这背后的代码是:
$dataArray = array();
while($r = mysql_fetch_array($result))
{
$dataArray[] = $r;
}
print json_encode($dataArray, JSON_UNESCAPED_UNICODE);
有什么想法吗?
答案 0 :(得分:6)
这是因为mysql_fetch_array()
的默认行为是返回列名和索引键控数组。
使用mysql_fetch_assoc()
或设置mysql_fetch_array()
的第二个参数。
while($r = mysql_fetch_assoc($result)) {
$dataArray[] = $r;
}
答案 1 :(得分:0)
您应该设置另一种获取方式。它现在使用基于0的索引及其名称来获取所有列。
这应该按预期工作:
$dataArray = array();
while($r = mysql_fetch_array($result, MYSQL_ASSOC))
{
$dataArray[] = $r;
}
print json_encode($dataArray, JSON_UNESCAPED_UNICODE);
答案 2 :(得分:0)
你得到这个是因为你可以通过名字或列索引来访问结果,但是你要序列化整个事物,所以两种获取数据的方式都会出现。
答案 3 :(得分:0)
试试这个
//$dataArray = array();
while($r = mysql_fetch_array($result))
{
$dataArray[] = $r;
}
print json_encode($dataArray, JSON_UNESCAPED_UNICODE);
我评论了第一行。因为你使用了那样的$ dataArray []。