1.问题背景
对于goctl自动生成的model代码文件,对于非null的时间数据列,一定会产生如下问题
deleted_at\": unsupported Scan, storing driver.Value type \u003cnil\u003e into type *time.Time"
例如以上的问题,不论是插入还是删除部分。
由于本人暂时无法解决根本上的问题,于是采取以下方法。
2.暂时的解决方案
2.1 sql文件的修改
本人使用的sql文件,进行自动生成model代码文件的增删改查,对于时间列的处理如下,让mysql自动插入和更新数据列。

2.2 对于生成的 xxx_gen.go 文件修改
原来的代码

修改后的代码

可以看到更改的后缀为rows的字符,由于主键查找或者是需要回表查找的部分,sql查询语句都和这个有关,所以考虑把更新和创建时间的列排除在外,避免导致问题的发生。
model数据结构的变动

将数据部分的创建时间列和更新时间列删除,使得数据赋值顺利进行。
这样子就不会产生bug,也可以顺利插入修改mysql数据了。
对于后续需要时间数据的部分,可以在gen后缀的文件中自定义方法,可以考虑引入orm进行数据解析获取。