json显示mysql结果的重复输出

时间:2013-07-25 19:50:15

标签: php json

我正在尝试打印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);

有什么想法吗?

4 个答案:

答案 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 []。