接口同步会涉及到增加或减少字段,每次增减都要改代码太麻烦,如果直接通过PG的函数生成报文JSON字符串,这样只需要改函数就可以了
一、单行数据转 JSON 对象
1. row_to_json:整行转 JSON
把查询的一行数据直接变成一个 JSON 对象
sql
-- 示例:用户表单行转 JSON
SELECT row_to_json(users) FROM users WHERE id = 1;
结果:
sql
{"id":1,"name":"张三","age":25,"email":"zhangsan@test.com"}
json_build_object:自定义键名转 JSON
手动指定 JSON 的键 (key)和值 (value),灵活可控
sql
-- 自定义键名,只返回需要的字段
SELECT
json_build_object(
'userId', id,
'userName', name,
'userAge', age
) AS user_json
FROM users
WHERE id = 1;
结果:
sql
{"userId":1,"userName":"张三","userAge":25}
二、多行数据转 JSON 数组
1. json_agg + 子查询(标准数组)
把多行结果打包成JSON 数组字符串
sql
-- 所有用户转 JSON 数组
SELECT json_agg(users) FROM users;
-- 只筛选指定字段转数组
SELECT json_agg(
json_build_object('id',id,'name',name)
) FROM users WHERE age > 20;
结果:
sql
[{"id":1,"name":"张三"},{"id":2,"name":"李四"}]
2. array_to_json + 数组(简单数组)
把普通 PostgreSQL 数组转 JSON 数组
sql
SELECT array_to_json(ARRAY[1,2,3,4]); -- [1,2,3,4]
SELECT array_to_json(ARRAY['苹果','香蕉']); -- ["苹果","香蕉"]
三、拼接复杂嵌套 JSON
- 嵌套 JSON 对象
sql
SELECT json_build_object(
'code', 200,
'msg', 'success',
'data', json_build_object(
'user', row_to_json(users),
'createTime', now()
)
) FROM users WHERE id = 1;
结果:
sql
{
"code":200,
"msg":"success",
"data":{
"user":{"id":1,"name":"张三","age":25},
"createTime":"2025-05-20 10:00:00"
}
}
- 嵌套 JSON 数组
sql
SELECT json_build_object(
'total', 2,
'list', json_agg(users)
) FROM users;
四、直接输出纯 JSON 字符串(无引号转义)
默认返回的是 json/jsonb 类型,如果你需要纯文本字符串 ,用 ::text 强转:
sql
-- 输出标准 JSON 字符串
SELECT row_to_json(users)::text FROM users WHERE id = 1;
复杂的json数据就需要自己摸索了
所有函数都是 PostgreSQL 内置,无需安装扩展,直接使用