您现在的位置是:网站首页> 编程资料编程资料
解决Go gorm踩过的坑_Golang_
2023-05-26
361人已围观
简介 解决Go gorm踩过的坑_Golang_
使用gorm.Model后无法查询数据
Scan error on column index 1, name “created_at”
提示:
Scan error on column index 1, name “created_at”: unsupported Scan, storing driver.Value type []uint8
解决办法:
打开数据库的时候加上parseTime=true
root:123456@tcp(127.0.0.1:3306)/mapdb?charset=utf8&parseTime=true
补充:golang Gorm 的使用总结
建立结构体时可以通过 TableName来指定要查找的表名
func (CoinLog) TableName() string { return "coin_log" }通过gorm的映射指定对应表的列
ID int64 `gorm:"column:id" json:"id"`
通过预加载可以实现各个模型之间的一对多关系,例如下面的代码,其中device结构体对应多个DeviceModular,DeviceModular又有多个CommWeimaqi
通过下面的查询语句可以查询出对应的相关联数据
db.SqlDB.Preload("DeviceModular", "modular_type=1").Preload("DeviceModular.CommWeimaqi").Find(&device)gorm暂时不支持批量插入
可以通过下面的方式完成批量插入的功能
tx := db.SqlDB.Begin() sqlStr := "INSERT INTO report_form (id,create_time,choose_count, device_fall_count,game_order_count,coin_count,member_count," + "day_member_count,visit_count,lgz_coin_count,weimaqi_coin_count,store_id,real_coin_count,m_coin_count,coin_spec) VALUES " vals := []interface{}{} const rowSQL = "(?,?, ?, ?, ?, ?, ?, ?, ?, ?,?,?,?,?,?)" var inserts []string for _, elem := range reportForms { inserts = append(inserts, rowSQL) vals = append(vals, elem.ID, elem.CreateTime, elem.ChooseCount, elem.DeviceFallCount, elem.GameOrderCount, elem.CoinCount, elem.MemberCount, elem.DayMemberCount, elem.VisitCount, elem.LgzCoinCount, elem.WeimaqiCoinCount, elem.StoreId, elem.RealCoinCount, elem.MCoinCount, elem.CoinSpec) } sqlStr = sqlStr + strings.Join(inserts, ",") err := tx.Exec(sqlStr, vals...).Error if err != nil { tx.Rollback() fmt.Print(err) }else { tx.Commit() }以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
您可能感兴趣的文章:
相关内容
- Go 实现HTTP中间人代理的操作_Golang_
- golang 实现一个负载均衡案例(随机,轮训)_Golang_
- golang 实现一个restful微服务的操作_Golang_
- 聊聊Go语言编译github上的项目遇到的坑_Golang_
- golang 如何自动下载所有依赖包_Golang_
- goland 实现自动格式化代码_Golang_
- go run main.go 一直提示找不到包的解决方案_Golang_
- golang 如何删除二进制文件中的源码路径信息_Golang_
- Golang 删除文件并递归删除空目录的操作_Golang_
- Golang 文件操作:删除指定的文件方式_Golang_
