卓越飞翔博客卓越飞翔博客

卓越飞翔 - 您值得收藏的技术分享站
技术文章33967本站已运行390

转到 time.Time 到 postgresql timestamptz 无法使用 time.Now() 保存

转到 time.time 到 postgresql timestamptz 无法使用 time.now() 保存

问题内容

嗨,我是 golang 新手,我正在尝试插入 time.Now() 值。 Time 类型的变量奇怪的是,我既没有收到错误,也没有处理提交,而是执行当我尝试插入代码时,代码被停止。有人可以帮我看看我应该尝试的价值是什么吗?

数据库: 更改表 abc 添加列创建的 timestamptz NULL;

结构体{ 创建时间.时间 db:"已创建" }

插入前已设置的值 创建=时间.Now()

我希望数据库与新记录一起保存


正确答案


为了让任何外部库能够查看您的结构字段,需要导出它们,即名称必须以大写字母开头。

由于您的定义使用小写字母定义了 created 时间,因此只有包内的代码才能看到该字段。这就是为什么您的数据库接口将“created”设置为 null - 据其所知,没有为该字段提供任何值。

type Foo struct { 
    Created time.Time db:"created"
}

注意:如果您碰巧使用 gorm 与数据库交互,它实际上默认支持您尝试执行的操作,只需将结构字段命名为 createdat: https://gorm.io/docs/conventions.html#createdat

卓越飞翔博客
上一篇: chromedp 如何从多个具有动态名称的文本区域中选择特定文本区域
下一篇: 返回列表
留言与评论(共有 0 条评论)
   
验证码:
隐藏边栏