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 内置,无需安装扩展,直接使用

相关推荐
haven-85210 小时前
AI Agent 生态核心概念详解:Agent、MCP、Skill 与 JSON-RPC
人工智能·rpc·json
_xaboy10 小时前
开源Vue组件FormCreate通过 JSON 生成TinyVue表单
前端·vue.js·低代码·开源·json·表单设计器
IvorySQL11 小时前
PostgreSQL 技术日报 (5月31日)|内核功能研讨,PG 大会赛事动态
数据库·postgresql
yumgpkpm11 小时前
华为HUAWEI昇腾910B下千问Qwen3.6-27B在的推理加速实践
sql·华为·langchain·json·ai编程·ai写作·gpu算力
阿坤带你走近大数据12 小时前
Postgresql的介绍
数据库·postgresql·关系型数据库
阿坤带你走近大数据13 小时前
GREENPLUM的介绍
数据仓库·postgresql·pgsql·mpp
SilentSamsara13 小时前
文件与数据处理:CSV/JSON/Excel/Parquet 高效操作与内存优化
开发语言·python·青少年编程·性能优化·json·excel
逍遥德13 小时前
PostgreSQL ---【序列】用法详解
数据库·后端·sql·postgresql
逍遥德13 小时前
PostgreSQL --- 自增主键【序列】的避坑指南
数据库·后端·sql·mysql·postgresql·sqlserver
l1t14 小时前
DeepSeek总结的PostgreSQL 19 中的 SQL/PGQ:无需图数据库的图查询
数据库·sql·postgresql