首页 > 后端开发 > Golang > 正文

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

WBOY
发布: 2024-02-05 22:42:08
转载
1198 人浏览过

转到 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

以上是转到 time.Time 到 postgresql timestamptz 无法使用 time.Now() 保存的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:stackoverflow.com
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板