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 [重复]的主要内容,如果未能解决你的问题,请参考以下文章

PHP · MySQL函数

通过php从mysql结果创建json对象[重复]

PHP 基础(12)之使用PHP操作MySQL

在PHP中将MySQL记录集转换为JSON字符串[重复]

PHP连接mysql时mysql_connect()函数不可用,报500错误

如何更新重复列值上的 mySQL 键