我想仅使用简单的MySQL命令将结果表转换为MySQL中的JSON数组。例如查询
SELECT name, phone FROM person;
| name | phone | | Jack | 12345 | | John | 23455 | 预期的JSON输出为
[ { "name": "Jack", "phone": 12345 }, { "name": "John", "phone": 23455 } ] 有没有办法在普通的MySQL中做到这一点?
新解决方案:
使用您的精彩评论构建,谢谢!
SELECT JSON_ARRAYAGG(JSON_OBJECT('name', name, 'phone', phone)) from Person; 旧解决方案:
在@Schwern的帮助下,我设法提出了这个查询,这似乎行得通!
SELECT CONCAT( '[', GROUP_CONCAT(JSON_OBJECT('name', name, 'phone', phone)), ']' ) FROM person;来源:stack overflow
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。