x893675 / note

my note
6 stars 0 forks source link

gorm使用 #10

Open x893675 opened 4 years ago

x893675 commented 4 years ago

orm优点:

缺点:

留意不合法的时间值

MySQL的DATE/DATATIME类型可以对应Golang的time.Time。但是,如果DATE/DATATIME不慎插入了一个无效值,例如2016-00-00 00:00:00, 那么这条记录是无法查询出来的。会返回gorm.RecordNotFound类型错误。零值0000-00-00 00:00:00是有效值,不影响正常查询。

留意tag sql:"default:null"

gorm对各种tag的支持非常完善。但是有些行为跟直觉不太一致,需要注意。当对某字段设置tagsql:"default:null"时,你想通过update设置该字段为null就不可能了,只能通过raw sql。这是gorm设计的取向问题。

如何通过gorm设置字段为null值

gorm给出了两种方法,以string为例:

在golang中,声明该字段为*string 使用sql.NullString类型

db连接时可以更改时区