PostgreSQL 生成 JSON 字符串

接口同步会涉及到增加或减少字段,每次增减都要改代码太麻烦,如果直接通过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"}
  1. 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

  1. 嵌套 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"
  }
}
  1. 嵌套 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 内置,无需安装扩展,直接使用

相关推荐
l1t6 小时前
DeepSeek总结的pg_clickhouse v0.3.0的新特性
clickhouse·postgresql
赵渝强老师7 小时前
【赵渝强老师】金仓数据库的运行日志文件
数据库·postgresql·oracle·国产数据库
D3bugRealm7 小时前
pgvector:PostgreSQL 原生向量搜索扩展
数据库·其他·postgresql
Java面试题总结8 小时前
PostgreSQL 性能调优:内存、I/O 与连接管理
数据库·postgresql
Kiyra8 小时前
Query Rewrite 不是越智能越好:RAG 检索的精确词保护与动态召回
redis·websocket·junit·单元测试·json
阿里云瑶池数据库8 小时前
如何破解多租户隔离与性能难题?PolarDB PostgreSQL实战指南
数据库·postgresql
Msshu1239 小时前
XSP25全协议 100W PD快充诱骗芯片_串口读电压电流信息
hive·云计算·json·database·memcached
水火既济__9 小时前
hive中加载json数据建表(大规模)
hive·hadoop·json
朝新_10 小时前
【LangChain】输出解析器 Str/Pydantic/JSON 解析器用法详解 告别模型乱输出
microsoft·langchain·json