MySQL 查数据转Json

将数据库表里的字段查询出来并且连接成json格式的实现方法

SELECT CONCAT('[', GROUP_CONCAT(JSON_OBJECT( 
'key-name',col1,'keyname2',col2,……,'key-namen',coln)), ']') as json_result 
FROM tablename where col1=83

结果会将查询的数据一行行用{}返回,行之间","分隔,最终结果[]展示--主要是你写了concat [ ]

[{"key-name": value1,……"key-namen": "valuen"},{}, {"line-n key-name": "value"}]

有个坑:

        1,代码里是单引号和逗号,结果是双引号和冒号哦~~别把结果直接贴代码里JSON_OBJECT, 这样是跑不通的。        

        2,MySQL种concat 函数返回的结果是限制长度的,筛选条件适当加点儿让结果不那么多,主要也看选多少个字段,可以用这个看下系统设置长度,然后修改下:

show VARIABLES like '%concat%'

MySQL 查数据转Json_第1张图片

修改全局或者当前session的值

set GLOBAL/SESSION group_concat_max_len=102400

你可能感兴趣的:(mysql,json,数据库)