我正在尝试从 mysql 中获取一个数组并打印每一列及其值。
这是我目前所拥有的:
获取所有列:
$query = "SHOW COLUMNS FROM user_settings";
$resultx = mysql_query($query);$temp=0;$p = array();
while ($row = mysql_fetch_array($resultx)) {
$p[$temp] = $row["Field"];$temp++;
}
Foreach column name fetch data where user id = $SESSION['id']
foreach ($p as $f) {
$json = array();
$newquery = "SELECT * FROM user_settings WHERE uid = '" . $_SESSION['id'] ."'";
$newresult = mysql_query($newquery);
while($newrow = mysql_fetch_array($newresult)) {
$json[$f] = $newrow[$f];
}
print json_encode($json);
}
这很好用。问题是打印的数组是这样的:
{"column1":"data"}{"column2":"data"}{"column3":"data"}
相反,我希望打印 json 编码:
[{"column1":"data","column2":"data","column3":"data"}}
最佳答案
您可以删除所有这些,因为它是多余的。
$query = "SHOW COLUMNS FROM user_settings";
$resultx = mysql_query($query);$temp=0;$p = array();
while ($row = mysql_fetch_array($resultx)) {
$p[$temp] = $row["Field"];$temp++;
}
同时删除 foreach 循环,这样我们只剩下查询和该查询的 while 循环。
$json = array();
$newquery = "SELECT * FROM user_settings WHERE uid = '" . $_SESSION['id'] ."'";
$newresult = mysql_query($newquery);
print json_encode(mysql_fetch_assoc($newresult));
这应该使 json_encode() 函数编码一个多维结果数组。
还尝试删除 mysql_* 函数并使用 mysqli_* 函数或 PDO,因为 mysql_* 函数已弃用。
关于PHP & MYSQL : Get all columns, 从行中选择 * 并对结果进行 json 编码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27021422/