Getting problems with time.Time being null in database.

xuanbao · 2016-07-02 17:00:10 · 2036 次点击    
这是一个分享于 2016-07-02 17:00:10 的资源,其中的信息可能已经有所发展或是发生改变。

I am using MYSQL as a database and gorp as the ORM library.

It's getting an error on the Updated_At column because it is null. This is how I have it written in my model: Updated_At time.Time `db: "updated_at".

The work around I'm thinking about is initializing both Updated_At and Deleted_at to 0001-01-01 00:00:00 +0000 UTC. Is there a better work around?

The error btw:

sql: Scan error on column index 7: unsupported Scan, storing driver.Value type <nil> into type *time.Time


评论:

tgulacsi:

It says that use *time.Time.

chaseroyaleee:

Value type <nil> into type *time.Time

Ohhhh. It didn't sound that explicit to me sorry haha. It's working now!

tgulacsi:

Yup, in reál, it is a little bit more involved: driver.Value is an empty interface, it is "unpacked" into the pointer given in Scan; nil needs a pointer to a pointer, thus &(*time.Time).

chaseroyaleee:

Makes sense makes sense. Having this problem right now with posting the time. It's automatically making it 000-01-01, the 0 for time. Thinking about just changing the model from time.Time to an int instead. I'll make time to UNIX based. What do you think?

media_guru:

The mysql driver has a NullTime struct you can use. It has two fields: Valid (bool) and Time (time.Time)

Time will always be set and use the default time.Time value if the column was null. If it was null, Valid will be false

Be aware that if you use the same struct for json marshalling, that NullTime struct is gonna get marshaled as is.

interactiv_:

You'll get a lot of these everywhere there are potential null values and it sucks. If Go sql package was more like JDBC it would have been more manageable for any library that extends sql. So you either have to change your schema to eliminate null values, use pointers of int,string,... in your structs or use funky types provided by drivers. This is not a good API no matter what people say.

chaseroyaleee:

Yeah just ended up making them int64s and using Unix time because its a hassle haha

nathj07:

That's the empty value for time.Time. You can check it with the convenience function time.IsZero(). I've not used mysql with Go but in PostgreSQL the lib/pq library has a NullTime type that works great on these situations.


入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

2036 次点击  
加入收藏 微博
0 回复
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传