gpt4 book ai didi

PHP & MYSQL : Get all columns, 从行中选择 * 并对结果进行 json 编码

转载 作者:行者123 更新时间:2023-12-01 00:10:01 25 4
gpt4 key购买 nike

我正在尝试从 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com