GoZero的一个注意点,goctl生成代码不会处理时间字段

本文讲述了在使用goctl生成代码时,发现插入操作中时间字段未被赋值的问题。作者分析了原因,可能是出于数据库设计考虑,这些字段由数据库自动填充。给出了两种解决方案:自定义sql方法或在数据库层面设置时间。
摘要由CSDN通过智能技术生成

起因

进行一个功能的编写时发现goctl生成的代码在insert时候不把时间给赋值进去

于是懵逼开始寻找原因

探究

再查看发现

goctl在对xxxExpectAutoSet和RowsWithPlaceHolder赋值时候就去掉了所有跟时间相关的信息字段

于是去查看官方文档,依稀记得官方提供了示例

发现官方的goctl生成代码,也去掉了根时间相关的一类字段,并且在insert语句内并未赋值此字段

原因

这样设计的可能原因有如下

在许多数据库设计中,这些字段通常由数据库自动填充,统一这样设计可以避免一些矛盾

解决方式

第一种,实在需要对time后台处理的,参考我另外一个文章,自己拓展sql方法

GoZero微服务个人探究之路(八)-[mysql数据库]如何拓展由goctl生成的model代码里的方法-CSDN博客

第二种,在数据库设置时间

采用图中之类的关键字

---注意数据库服务器的时间

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

夏目艾拉

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值