查询 MySQL 以获取 JSON 输出
将结果表转换为 JSON 数组是数据操作和交换的有用功能。在 MySQL 中,这可以通过内置函数和运算符的组合来实现。
单个 JSON 数组的简单查询
从结果表,可以使用 JSON_ARRAYAGG 函数。此函数聚合指定列中的值并返回 JSON 数组。
例如,要使用普通 MySQL 命令将以下结果表:
| name | phone | | Jack | 12345 | | John | 23455 |
转换为 JSON 数组,请执行以下操作:可以使用查询:
SELECT JSON_ARRAYAGG(JSON_OBJECT('name', name, 'phone', phone)) FROM person;
此查询将生成以下 JSON array:
[ { "name": "Jack", "phone": 12345 }, { "name": "John", "phone": 23455 } ]
自定义 JSON 数组
要修改 JSON 数组的结构或内容,可以使用其他运算符和函数。例如,GROUP_CONCAT 函数可用于将多行连接成一个字符串。
考虑以下查询作为替代解决方案:
SELECT CONCAT('[', GROUP_CONCAT(JSON_OBJECT('name', name, 'phone', phone)), ']') FROM person;
此查询将生成与前面的示例相同的 JSON 数组。然而,它允许更灵活地自定义数组结构,例如包含附加元素或格式选项。
结论
这些 MySQL 命令提供了简单且将结果表转换为 JSON 数组的有效方法。无论您需要简单的数组结构还是自定义输出,都有一些选项可以满足您的特定需求,而无需使用外部语言或工具。
以上是如何将 MySQL 结果表转换为 JSON 数组?的详细内容。更多信息请关注PHP中文网其他相关文章!