从品牌网站建设到网络营销策划,从策略到执行的一站式服务
首先说明的是,在项目中使用orm的好处很多:
创新互联建站是一家以成都网站建设、网页设计、品牌设计、软件运维、成都网站推广、小程序App开发等移动开发为一体互联网公司。已累计为成都生料搅拌车等众行业中小客户提供优质的互联网建站和软件开发服务。
坏处也是显而易见的:
留意不合法的时间值
MySQL的DATE/DATATIME
类型可以对应Golang的time.Time
。但是,如果DATE/DATATIME
不慎插入了一个无效值,例如2016-00-00 00:00:00, 那么这条记录是无法查询出来的。会返回gorm.RecordNotFound
类型错误。零值0000-00-00 00:00:00是有效值,不影响正常查询。
留意tagsql:"default:null"
gorm对各种tag的支持非常完善。但是有些行为跟直觉不太一致,需要注意。当对某字段设置tagsql:"default:null"
时,你想通过update
设置该字段为null
就不可能了,只能通过raw sql
。这是gorm设计的取向问题。
如何通过gorm设置字段为null值
字段允许为null
值肯定是设计存在问题。但是,往往前人埋下的坑需要你去填。gorm作者给出了两种方法,以string
为例:
在golang中,声明该字段为*string
使用sql.NullString
类型
推荐使用后者。
留意连接串中的loc
例如通过如下连接串打开mysql连接:
parseTime=true&loc=Local
说明会解析时间,时区是机器的local时区。机器之间的时区可能不一致会设置有问题,这导致从相同库的不同实例查询出来的结果可能解析以后就不一样。因此推荐将loc统一设置为一个时区,如parseTime=true&loc=America%2FChicago
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。
成都网站建设公司地址:成都市青羊区太升南路288号锦天国际A座10层 建设咨询028-86922220
成都快上网科技有限公司-四川网站建设设计公司 | 蜀ICP备19037934号 Copyright 2020,ALL Rights Reserved cdkjz.cn | 成都网站建设 | © Copyright 2020版权所有.
专家团队为您提供成都网站建设,成都网站设计,成都品牌网站设计,成都营销型网站制作等服务,成都建网站就找快上网! | 成都网站建设哪家好? | 网站建设地图