gpt4 book ai didi

mysql - 如何将相同的 MYSQL 列作为 JSON 输出两次

转载 作者:行者123 更新时间:2023-11-29 00:51:57 25 4
gpt4 key购买 nike

我正在使用 MySQL 构建消息系统。到目前为止一切都很好,但我需要能够做一件特定的事情。

在其中一个表中,我有“sender_id”列。

我使用这个“sender_id”并通过一个函数运行它,然后检索用户头像并在返回的 JSON 响应中输出链接。

我需要此链接...但我还需要能够检索“sender_id”本身作为数字,以便我可以在 jquery 中对其进行测试。

所以我最终要复制原始“sender_id”并放入一种虚拟列“之前”,它已被我的“获取头像”功能处理。

我用来在查询等之后输出 JSON 的代码如下:-

/*
* Output
*/
$output = array(
"sEcho" => intval($_GET['sEcho']),
"iTotalRecords" => $iTotal,
"iTotalDisplayRecords" => $iFilteredTotal,
"aaData" => array()
);

while ( $aRow = mysql_fetch_array( $rResult ) )
{
$row = array();
for ( $i=0 ; $i<count($aColumns) ; $i++ )
{
if ( $aColumns[$i] == "version" )
{
/* Special output formatting for 'version' column */
$row[] = ($aRow[ $aColumns[$i] ]=="0") ? '-' : $aRow[ $aColumns[$i] ];
}
if ( $aColumns[$i] == "sender_id" )
{
/* Special output to render Avatar by user id */
$row[] = commentplayer_get_user_avatar($aRow[ $aColumns[$i] ]);

}
else if ( $aColumns[$i] == "message" )
{
/* General output */
$row[] = strip_slashes($aRow[ $aColumns[$i] ]);
}

else if ( $aColumns[$i] != ' ' )
{
/* General output */
$row[] = $aRow[ $aColumns[$i] ];
}
}
$output['aaData'][] = $row;
}

echo json_encode( $output );
?>

$aColumns 是前面定义的列数组,显然 'sender_id' 是其中之一。如您所见,我放入了一个条件语句,以便将 sender_id 重新作为头像链接而不是实际的 sender_id。因此,总而言之,我只需要能够将实际的 sender_id 和头像一起提取出来,最好放在一个单独的列中。

有什么想法吗?

最佳答案

您可以在处理 sender_id 列的代码中添加一行:

        if ( $aColumns[$i] == "sender_id" )
{
/* Output user id */
$row[] = $aRow[ $aColumns[$i]] );
/* Special output to render Avatar by user id */
$row[] = commentplayer_get_user_avatar($aRow[ $aColumns[$i] ]);

}

这将在每个返回的 JSON 行数组中的头像 URL 之前插入用户 ID。

事实上,去掉列上的 for 循环会更好,只用你需要的项目填充 $row,按专有名称索引而不是根据顺序.这使得查看实际附加到 $output 的内容变得更加容易。这确实意味着在客户端解释 JSON 时,您必须将行视为对象而不是数组。

    $row = array(
"version" => ($aRow["version"] == "0") ? '-' : $aRow["version"],
"sender_id" => $aRow["sender_id"],
"avatar" => commentplayer_get_user_avatar($aRow["sender_id"]),
"message" => strip_slashes($aRow["message"]),
// other items here
);

关于mysql - 如何将相同的 MYSQL 列作为 JSON 输出两次,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8134887/

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