You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
1.4 KiB
1.4 KiB
formatime
Customize the format of the time in golang, can be used in conjunction with the gorm, no need to use sql.nullTime, and can return the specified time format in the json serialization of the struct
Installation
go get github.com/golangkit/formatime
Usage
type foo struct {
ID int64 `gorm:"column:id"`
CreatedAt formatime.Date `gorm:"column:created_at" json:"created_at"`
UpdatedAt formatime.Timestamp `gorm:"column:updated_at" json:"updated_at"`
DeletedAt formatime.CustomTime `gorm:"column:deleted_at" json:"deleted_at"`
}
func Test_json(t *testing.T) {
b := foo{
CreatedAt: formatime.NewDateNow(),
UpdatedAt: formatime.NewTimestampNow(),
DeletedAt: formatime.NewCustomTimeNow("Jan _2 15:04:05"),
}
text, err := json.Marshal(&b)
if err != nil {
t.Fatal(err)
} else {
log.Print(string(text))
}
}
func Test_gorm(t *testing.T) {
b := &foo{}
gorm.DB.First(b)
text, err := json.Marshal(&b)
if err != nil {
t.Fatal(err)
} else {
log.Print(string(text))
}
}
// log
{
"created_at":"2019-10-29",
"updated_at":"1572312916",
"deleted_at":"Oct 29 09:35:16"
}