我正在尝试打印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[]。