golang gorm中格式化时间问题详解

作者:yuanshuli11 时间:2023-07-12 09:45:21 

前言

最近在开发项目时遇到了发现一个问题,

gorm虽然可以自动帮你维护 created_at、updated_at、deleted_at这些关键时间字段。但是其原理与弊端需要了解一下。

1.使用方法

通过自定义一个localtime的结构,来控制时间的格式


package utils
import (
"time"
//"strconv"
"fmt"
"database/sql/driver"
"strconv"
)
type LocalTime struct {
time.Time
}
func (t LocalTime) MarshalJSON() ([]byte, error) {
//格式化秒
seconds := t.Unix()
return []byte(strconv.FormatInt(seconds, 10)), nil
}
func (t LocalTime) Value() (driver.Value, error) {
var zeroTime time.Time
if t.Time.UnixNano() == zeroTime.UnixNano() {
return nil, nil
}
return t.Time, nil
}
func (t *LocalTime) Scan(v interface{}) error {
value, ok := v.(time.Time)
if ok {
*t = LocalTime{Time: value}
return nil
}
return fmt.Errorf("can not convert %v to timestamp", v)
}

此时dao的字段结构为


type TestDao struct{
  Id    uint    `gorm:"primary_key,AUTO_INCREMENT" json:"id"`
CreatedAt  LocalTime `json:"-"`
UpdatedAt  LocalTime `json:"update_at"`
DeletedAt  *LocalTime `json:"-"`
}

2.实现原理

其实现方式其实是通过在save变更时,通过callback功能,将其定义为当前时间。文章可参考 传送门

这样你就可以通过自定义的LocalTime来控制时间格式。

3.弊端与建议

因为在程序运行时,createAt这类字段的类型还是 LocalTime,所以如果你想自己给其复制,是不太容易做到的。

例如,你想在程序运行时改一下其createAt的时间。你做不到! 因为它的类型是LocalTime,而你的时间要么是时间戳,要么是一个字符串,类型不匹配。。。是不是很尴尬???

所以建议这类保留字段还是不要在程序运行时去修改。只用它作为记录或标识即可。如果真的需要更改时间,还是自己维护字段的内容吧。例如用int存时间戳或string存字符串。然后每次变更时,去修改它的值。

当然也可以将这工作自己封装成一个callback函数,这样你就能够随意控制这个字段了。可参考上文传送门中的内容。

所以,想吐槽的是,gorm对时间格式化的这种实现方式,太不人性化了!

来源:https://studygolang.com/articles/21781

标签:golang,gorm,格式化
0
投稿

猜你喜欢

  • Python输出由1,2,3,4组成的互不相同且无重复的三位数

    2021-07-26 10:54:42
  • Mysql常见bug及解决方案超详细讲解

    2024-01-15 17:20:56
  • PyQt5入门之基于QListWidget版本实现图片缩略图列表功能

    2023-07-15 08:32:52
  • js处理括弧配对替换的方法

    2008-01-16 13:48:00
  • vue 封装面包屑组件教程

    2024-05-02 17:11:11
  • select into from和insert into select的使用举例详解

    2024-01-25 03:27:28
  • python 写的一个爬虫程序源码

    2022-08-10 16:00:47
  • Python是什么 Python的用处

    2021-12-20 05:55:37
  • Python实现将长图制作成一个视频

    2022-09-28 06:09:09
  • JS简单实现文件上传实例代码(无需插件)

    2024-04-10 16:19:24
  • python操作openpyxl导出Excel 设置单元格格式及合并处理代码实例

    2022-09-27 13:07:54
  • PHP实现搜索相似图片

    2024-05-03 15:52:53
  • Python使用sort和class实现的多级排序功能示例

    2021-01-30 23:54:46
  • php实现的简单检验登陆类

    2023-11-22 06:13:33
  • Dreamweaver如何制作会移动的广告条

    2010-10-20 20:04:00
  • mysql中count(), group by, order by使用详解

    2024-01-26 00:48:11
  • 在Python中操作文件之seek()方法的使用教程

    2023-08-01 14:58:01
  • Linux系统下mysqlcheck修复数据库命令(详解)

    2024-01-24 14:42:10
  • Linux下mysql的root密码修改方法

    2024-01-13 17:39:44
  • echarts柱状堆叠图实现示例(图例和x轴都是动态的)

    2024-04-29 13:21:03
  • asp之家 网络编程 m.aspxhome.com