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"强行套壳,反而增加歧义和维护成本。 幻导航网 发现优质实用网站,开启网络探索之旅!

相关推荐
雪度娃娃1 分钟前
存储器层次结构——磁盘硬盘存储
服务器·网络·数据库·计算机组成原理
郝学胜-神的一滴1 分钟前
干货版《算法导论》07:递归视角下的选择排序与归并排序
java·数据结构·c++·python·程序人生·算法·排序算法
shehuiyuelaiyuehao15 分钟前
多线程入门
java·python·算法
暴力求解19 分钟前
Mysql数据库基础
数据库·mysql·操作系统
Oo9201 小时前
Prompt工程核心与Python 字典
python·ai编程
意倾城1 小时前
MySQL最左前缀匹配原则
数据库·mysql
暴躁小师兄数据学院1 小时前
【AI大数据工程师特训笔记】第13讲:数据库性能手术刀
大数据·数据库·数据仓库·sql·postgresql
feeday1 小时前
gpt4o 图像反推提示词
开发语言·人工智能·python
沈浩(种子思维作者)1 小时前
没有错误,正确将一文不值
人工智能·python·算法·量子计算
smith成长之旅1 小时前
06 | Mem0 框架分析:为什么要从记忆中提取实体?——Entity Store 的设计动机与工程实现
人工智能·python