go-zero: sqlx 对timestamp 格式数据问题

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进行数据解析获取。

3.参考链接

  1. 我是如何用go-zero 实现一个中台系统的 - jackluo - 博客园
相关推荐
API_technology17 分钟前
淘宝API+爬虫混合方案:合规采集历史价格与评价数据
前端·数据库·爬虫·数据挖掘
2401_8319433222 分钟前
【SQL性能优化】预编译SQL:从注入防御到性能飞跃
数据库·sql·性能优化
阿黄学技术1 小时前
Redis场景问题2:缓存击穿
java·数据库·redis·缓存
昔我往昔1 小时前
Redis的缓存雪崩和缓存穿透的理解和如何避免
数据库·redis·缓存
shaoweijava2 小时前
基于SpringBoot的美食设计网站(源码+数据库)
数据库·spring boot·mysql·mybatis
网络风云3 小时前
Flask(六)数据库与模型操作
数据库·python·flask
三氧化真5 小时前
使用FastExcel时的单个和批量插入的问题
java·数据库·mybatis
程序猿阿伟6 小时前
《探秘SQL的BETWEEN:解锁数据范围查询的深度奥秘》
大数据·数据库·sql
ManageEngine卓豪6 小时前
什么是SQL作业
数据库·数据库性能·sql作业
THE MATRIX-HZB7 小时前
DQL语句-distinct去重
数据库·mysql·github