Golang 往mysql的datetime类型插入数据出错解决方法

先说结果,往mysql datetime类型插入数据的时候,golang用string类型就可以解决了

mysql中timestamp类型和datetime类型的值的范围是不同的,可以参考下面这个网站,但是golang中只有timestamp类型(time.Time),没有datetime,这时候golang中就需要用string类型对应mysql的datetime类型了。

MySQL 时间类型 DATE、DATETIME和TIMESTAMP - 东山絮柳仔 - 博客园1.DATE、DATETIME和TIMESTAMP 表达的时间范围 2.DATETIME和TIMESTAMP 最大时间精确度 5.7 之后的版本(其实应该说5.6.5),在默认的秒精确度上,可以带小数https://www.cnblogs.com/xuliuzai/p/10901425.html比如说有一个表

dtb_test
column type
ID int
created_at datetime

我想通过golang中的Gorm往dtb_test.created_at插入,"9999-12-31 23:59:59"数据,这时候go正确的写法是下面这样

type DtbTest struct {
	ID int       `json:"id"`                     
	CreatedAt                 string `json:"created_at"`
}

data := &DtbTest{}
data.ID = 1
data.CreatedAt = "9999-12-31 23:59:59"

db.Table("dtb_text").Create(&data).Error

这样"9999-12-31 23:59:59"数据就可以正常插入了。

错误的写法,运行后会出下面的错误

year is not in the range [1, 9999]: 10000

type DtbTest struct {
	ID int       `json:"id"`                     
	CreatedAt                 time.Time `json:"created_at"`
}

data := &DtbTest{}
data.ID = 1
data.CreatedAt = time.Parse("2006-01-02 15:04:05", "9999-12-31 23:59:59")

db.Table("dtb_text").Create(&data).Error

你可能感兴趣的:(golang,go,mysql)