golang如何处理PostgreSQL JSONB字段_golang PostgreSQL JSONB字段处理方法

PostgreSQL的jsonb字段在Go中需用json.RawMessage或自定义struct接收,不可直接scan到string或sql.NullString;写入NULL须用nil指针,查询时应避免SELECT 配合[]interface{}。PostgreSQL 的 jsonb 字段在 Go 中不能直接 scan 到 stringPostgreSQL 返回的 jsonb 是二进制格式,不是纯文本。如果用 Scan(&s) 扫到 string,会报错:sql: Scan error on column index 0: unsupported Scan, storing driver.Value type []uint8 into type *string。正确做法是用 json.RawMessage 或自定义 struct 接收:json.RawMessage 最轻量,适合"先读再解析",避免重复 unmarshal定义 struct 并用 Scan 直接映射,要求字段结构稳定;否则容易 panic 或丢字段别用 interface{} + json.Unmarshal,Go 的 json 包对 interface{} 解析后类型不明确(比如数字全转 float64),后续取值易出错var data json.RawMessageerr := row.Scan(&data) // ? 正确// 后续可多次解析:json.Unmarshal(data, &v)用 sql.NullString 包装 jsonb 字段会失效sql.NullString 只能处理 PostgreSQL 的 text 或 varchar 类型,对 jsonb 无效。即使字段允许 NULL,直接扫进 sql.NullString 仍会触发上面那个 []uint8 → string 的类型错误。真正支持 NULL 的 JSONB 接收方式只有两种:立即学习"go语言免费学习笔记(深入)";*json.RawMessage(指针,nil 表示 NULL)自定义类型,实现 sql.Scanner 和 driver.Valuer,内部用 json.RawMessage 存储别为了"看起来像 NullString"强行套壳,反而增加歧义和维护成本。 幻导航网 发现优质实用网站,开启网络探索之旅!

相关推荐
hmywillstronger1 分钟前
【Python】从SAP2000 XML截面库提取数据到Excel
xml·python·excel
常常有3 分钟前
中间件与依赖系统:构建高效 Web 后端的双重利器
开发语言·python·中间件·fastapi
Zephyr_014 分钟前
python基础
python
Royzst15 分钟前
一、集合概述(前置基础)
开发语言·windows·python
todoitbo17 分钟前
CTE 与外层 JOIN 的条件下推:原理、边界与验证方法
数据库·join·cte
平安的平安18 分钟前
Python大模型Function Calling实战:让AI拥有工具使用能力
开发语言·人工智能·python
TEC_INO21 分钟前
Linux56:读取人脸图片并把特征值保存到sqlite3数据库
数据库·oracle
刘~浪地球21 分钟前
MongoDB分片集群实战:水平扩展海量数据
数据库·mongodb
源码之家23 分钟前
计算机毕业设计:Python中药材数据可视化与智能分析平台 Django框架 中药数据分析 医药数据分析数据分析 可视化 爬虫 (建议收藏)✅
python·深度学习·信息可视化·数据分析·django·课程设计
鸽芷咕23 分钟前
KingbaseES中的PL_SQL编程:存储过程、函数、触发器与包的开发指南
数据库·sql·oracle