PHP MySQL连接表为JSON [重复]
Posted
技术标签:
【中文标题】PHP MySQL连接表为JSON [重复]【英文标题】:PHP MySQL join table as JSON [duplicate] 【发布时间】:2017-04-10 16:24:41 【问题描述】:我有两个不同的表 - 一个称为“产品”,其中包含有关在线商店产品的信息,另一个称为“图像”的表包含相应的产品图像(每个产品的多个图像)。 我想在主表“产品”上加入表“图像”并以 JSON 格式输出结果。
“产品”表如下所示(简化):
id | name
----|--------
57 | apple
58 | tomato
59 | ...
以及产品图片的“图片”表:
img_id | img | p_id | listorder
-------|-------------|------|----------
32 | apple1.jpg | 57 | 1
33 | apple2.jpg | 57 | 2
34 | tomato1.jpg | 58 | 1
35 | ... | ... | ...
到目前为止,我的查询是这样的:
$sql = "SELECT
p.id as p_id,
p.name as p_name,
i.*
FROM products p
JOIN (SELECT * FROM images WHERE listorder=1)
AS i ON (i.p_id = p.id)";
因此输出(在将数据提取到数组并转换为 JSON 之后)看起来像这样:
[
"id": "57",
"name": "apple",
"img": "apple1.jpg"
,
"id": "58",
"name": "tomato",
"img": "tomato1.jpg"
]
所以我的问题是:如何输出以下内容?
[
"id": "57",
"name": "apple",
"img": ["img_id": "32","img": "apple1.jpg", "img_id": "33","img": "apple2.jpg"]
,
"id": "58",
"name": "tomato",
"img": ["img_id": "34","img": "tomato1.jpg"]
]
【问题讨论】:
您是如何获得当前 JSON 输出的?这是来自 mysql 还是 php? ` WHERE listorder=1` 将其限制为每个产品一张图片 很可能是手动的,我认为您必须使用多个查询来制作自己的数组和 json 编码 【参考方案1】:将 JSON 解码为 Array 并将它们合并,然后再次编码为 JSON。试试看
两个功能:
array_merge($array1, $array2)
json_encode()
【讨论】:
感谢您的回答 - 虽然链接到在线其他地方的文档通常很有用,但如果您可以使用一些代码演示如何使用这些函数来解决原始问题,这也将非常有帮助。 【参考方案2】:SELECT
p.id as p_id,
p.name as p_name,
group_concat(concat('"img_id":"',i.img_id,'"img":"',i.img,'"') separator ',') as img
FROM products p
JOIN (SELECT * FROM images WHERE listorder=1)
AS i ON (i.p_id = p.id)
GROUP BY p.id,p.name
【讨论】:
以上是关于PHP MySQL连接表为JSON [重复]的主要内容,如果未能解决你的问题,请参考以下文章