doqdcks3948 2018-04-02 22:25
浏览 702
已采纳

Go的sql.NullString的值是否可以预测为空?

After using db.Query and rows.Scan to populate a sql.NullString with a NULL value such that its .Valid field is false, is it guaranteed that its .String will hold the empty string ""?

I ask because it would be snazzy if I could use this:

res := ns.String

Instead of this:

var res string
if ns.Valid {
    res = ns.String
}

https://golang.org/pkg/database/sql/#NullString

  • 写回答

1条回答 默认 最新

  • dota220141003 2018-04-02 22:34
    关注

    In the current implementation yes, but the docs explicitly say to check Valid before using String. Ignore the docs at your own risk.

    If you want to be safe, simply copy the type into your own package; then you know it's not going to change with the next Go release.

    If you don't do that, I strongly suggest to write a test:

    func TestEmptyNullString(t *testing.T) {
        var x sql.NullString
        x.String = "foo"
        x.Scan(nil)
        if x.String != "" {
            t.Error("string not empty after Scan")
        }
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵