• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    解决Go gorm踩过的坑

    使用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=utf8parseTime=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()
      }

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。

    您可能感兴趣的文章:
    • gorm update传入struct对象,零值字段不更新的解决方案
    • gorm操作MySql数据库的方法
    • Go基于GORM 获取当前请求所执行的 SQL 信息(思路详解)
    • Golang 使用gorm添加数据库排他锁,for update
    • golang Gorm与数据库完整性约束详解
    • golang gorm 结构体的表字段缺省值设置方式
    • golang gorm 计算字段和获取sum()值的实现
    • gorm FirstOrCreate和受影响的行数实例
    上一篇:Go 实现HTTP中间人代理的操作
    下一篇:Golang中interface{}转为数组的操作
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    解决Go gorm踩过的坑 解决,gorm,踩过,的,坑,解决,