json显示mysql结果的重复输出


json showing duplicate output of mysql result

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

知道吗?

这是因为mysql_fetch_array()的默认行为是返回列名和索引键控数组。

使用mysql_fetch_assoc()或设置mysql_fetch_array()的第二个参数。

while($r = mysql_fetch_assoc($result)) {
    $dataArray[] = $r;
}

您应该设置另一个获取样式。现在,它使用基于0的索引和名称来获取所有列。

这应该按预期工作:

$dataArray = array();
while($r = mysql_fetch_array($result, MYSQL_ASSOC))
{
    $dataArray[] = $r;
}
print json_encode($dataArray, JSON_UNESCAPED_UNICODE);

您之所以得到这一点,是因为您可以通过名称或列索引访问结果,但您正在序列化整个过程,因此获取数据的两种方法都会出现。

尝试这个

//$dataArray = array();
while($r = mysql_fetch_array($result))
{
    $dataArray[] = $r;
}
print json_encode($dataArray, JSON_UNESCAPED_UNICODE);

我评论了第一行。因为你用的是$dataArray[]。