go语言的null值问题
关于go语言数据库存储和显示null值的问题困扰了我很久,并且也和群友讨论过这个问题,但是都没有得到相对满意和全面的答案。最近FQ找了几篇相对详细和权威的文章,分享给大家,希望和大家一起进步,go go go!
文章一:Go语言:解决数据库中null值的问题(转载国人文章)
文章二:How I handled possible null values from database rows in Golang?(需***)
文章三:Working effectively with database nulls(试验过不需要***)
Github:有没有专门的null值函数库?
https://github.com/guregu/null介绍
import "gopkg.in/guregu/null.v3"
null是一个具有合理选项的库,用于处理可空的SQL和JSON值
有两个包: null
及其子包zero
。
null
类型仅在null输入时被视为null,并且JSON将编码为null
。 如果您需要零并且null被视为单独的值,请使用这些值。
zero
中的类型在Go中被视为零值:空字符串输入将生成空零zero.String
,并且空字符串将JSON编码为""
。 这些类型的零值将被视为对SQL无效。 如果你需要零和null处理相同,使用这些。
所有类型都实现了sql.Scanner
和driver.Valuer
,因此您可以使用此库代替sql.NullXXX
。 所有类型还实现: encoding.TextMarshaler
, encoding.TextUnmarshaler
, json.Marshaler
和json.Unmarshaler
。
null包
import "gopkg.in/guregu/null.v3"
null.String
可以为空的字符串。
如果SQL源数据为空,则Marshals为JSON null。 零(空白)输入不会产生空字符串。 可以从sql.NullString
JSON输入或字符串输入解sql.NullString
。
null.Int
可以为null的int64。
如果SQL源数据为空,则Marshals为JSON null。 零输入不会产生null Int。 可以从sql.NullInt64
JSON输入解sql.NullInt64
。
null.Float
可空浮动64。
如果SQL源数据为空,则Marshals为JSON null。 零输入不会产生null Float。 可以从sql.NullFloat64
JSON输入解sql.NullFloat64
。
null.Bool
可空的布尔。
如果SQL源数据为空,则Marshals为JSON null。 虚假输入不会产生null Bool。 可以从sql.NullBool
JSON输入解sql.NullBool
。
null.Time
如果SQL源数据为空,则Marshals为JSON null。 使用time.Time
的封送者。 可以从pq.NullTime
和类似的JSON输入解pq.NullTime
。
零包装
import "gopkg.in/guregu/null.v3/zero"
zero.String
可以为空的字符串。
如果为null,将Marshal编排为空字符串。 空字符串输入生成空字符串。 空值和零值被认为是等价的。 可以从sql.NullString
JSON输入解sql.NullString
。
zero.Int
可以为null的int64。
如果为null,将Marshal编排为0。 0产生一个空Int。 空值和零值被认为是等价的。 可以从sql.NullInt64
JSON输入解sql.NullInt64
。
zero.Float
可空浮动64。
如果为null,将Marshal编排为0。 0.0产生一个null Float。 空值和零值被认为是等价的。 可以从sql.NullFloat64
JSON输入解sql.NullFloat64
。
zero.Bool
可空的布尔。
如果为null,将Marshal编排为false。 false
产生一个null Float。 空值和零值被认为是等价的。 可以从sql.NullBool
JSON输入解sql.NullBool
。
zero.Time
如果为null,将Marshal编排为零时间。 使用time.Time
的封送者。 可以从pq.NullTime
和类似的JSON输入解pq.NullTime
。
错误
json
的",omitempty"
结构标记现在无法正常工作。 它永远不会省略null或空String。 这可能最终会得到解决 。
go语言的null值问题的更多相关文章
- 为什么说JAVA中要慎重使用继承 C# 语言历史版本特性(C# 1.0到C# 8.0汇总) SQL Server事务 事务日志 SQL Server 锁详解 软件架构之 23种设计模式 Oracle与Sqlserver:Order by NULL值介绍 asp.net MVC漏油配置总结
为什么说JAVA中要慎重使用继承 这篇文章的主题并非鼓励不使用继承,而是仅从使用继承带来的问题出发,讨论继承机制不太好的地方,从而在使用时慎重选择,避开可能遇到的坑. JAVA中使用到继承就会有两 ...
- Docs-.NET-C#-指南-语言参考-关键字-值类型:可以 null 的值类型
ylbtech-Docs-.NET-C#-指南-语言参考-关键字-值类型:可以 null 的值类型 1.返回顶部 1. Nullable value types (C# reference) 2019 ...
- C/C++编程笔记:C语言NULL值和数字 0 值区别及NULL详解
在学习C语言的时候,我们常常会碰到C语言NULL值和数字 0 ,很多小伙伴搞不清楚他们之间的一个区别,今天我们就了解一下他们之间的区别,一起来看看吧! 先看下面一段代码输出什么: 输出<null ...
- 奇妙的NULL值,你知道多少
<NULL值的多义性分析> 谈到NULL值,很多人都是很熟悉,但是深入了解后,又感觉到陌生,对其含义和用法,都无法很准确的理解.NULL在数据库和编程语言中,存在的意义和附带的含义不同. ...
- Swift:消除Null值
由于在现代编程语言中这个无所不在的概念,许多程序猿可能倾向于相信null值是一个必须存在的瑕疵,创建一个没有它的编程语言是不可能的.他们可能会惊奇那些许多没有null值活的也很好的语言,这带来的结果就 ...
- sql server 2008 NULL值
SQL支持用NULL符号来表示缺少的值,它使用的是三值谓词逻辑,计算结果可是以TURE.FALSE或UNKNOWN. SQL中不同语言元素处理NULL和UNKNOWN的方式也有所不同,如果逻辑表达式只 ...
- 关于程序null值的见解
今天遇到了一个问题,查询一条数据,返回用list接,发现少了2个值(ssh框架).执行SQL少的这两个字段的值为null.上图说明一下: 可以看到第一次查询没有角标38.39的值. 是同一条SQL,第 ...
- R语言计算IV值
更多大数据分析.建模等内容请关注公众号<bigdatamodeling> 在对变量分箱后,需要计算变量的重要性,IV是评估变量区分度或重要性的统计量之一,R语言计算IV值的代码如下: Ca ...
- Docs-.NET-C#-指南-语言参考-关键字-值类型:bool
ylbtech-Docs-.NET-C#-指南-语言参考-关键字-值类型:bool 1.返回顶部 1. bool(C# 参考) 2015/07/20 bool 关键字是 System.Boolean ...
随机推荐
- 72. Edit Distance (String; DP)
Given two words word1 and word2, find the minimum number of steps required to convert word1 to word2 ...
- 140. Word Break II (String; DP,DFS)
Given a string s and a dictionary of words dict, add spaces in s to construct a sentence where each ...
- Dom对象总结介绍&事件介绍&增删查找标签
1.dom有5个属性,属性内容如下 下面开始介绍Dom属性,一共有5个属性 1.document object:文档对象 2.element object:标签对象 3.test object:文本对 ...
- 编辑距离12 · Edit Distance12
[抄题]: 给出两个单词word1和word2,计算出将word1 转换为word2的最少操作次数. 你总共三种操作方法: 插入一个字符 删除一个字符 替换一个字符 [思维问题]: [一句话思路]: ...
- Codeforces 658A. Robbers' watch 模拟
A. Robbers' watch time limit per test: 2 seconds memory limit per test: 256 megabytes input: standar ...
- Codeforces 595B. Pasha and Phone 容斥
B. Pasha and Phone time limit per test 1 second memory limit per test 256 megabytes input standard i ...
- easyui datagrid编辑
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Datagrid.aspx. ...
- sqlldr 笔记
表结构 CREATE table sqlloader_test ( f1 char(20), f2 char(20), f3 number(16), f4 date ); 数据文件data.csv 1 ...
- jquery统计显示或隐藏的元素个数
统计显示的checkbox的数量: 统计隐藏的checkbox数量:
- 2018.09.30 bzoj4025: 二分图(线段树分治+并查集)
传送门 线段树分治好题. 这道题实际上有很多不同的做法: cdq分治. lct. - 而我学习了dzyo的线段树分治+并查集写法. 所谓线段树分治就是先把操作分成lognlognlogn个连续不相交的 ...