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

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    golang gorm 计算字段和获取sum()值的实现

    计算表lb_ytt_user_money_log 中,字段money的和

    代码如下:

    var total_money []int
    sqlstr := `select 
     SUM(money) as total_money 
     from 
     lb_ytt_user_money_log 
     where 
     user_id = ? and l_type = 1 and status=1 and (create_time> ? and create_time = ?)`
    Db.Raw(sqlstr, userID, beginTimeNum, endTimeNum).Pluck("SUM(money) as total_money", total_money)

    Pluck

    将模型中的单个列作为地图查询,如果要查询多个列,可以使用Scan

    Db.Raw(sqlstr, userID, beginTimeNum, endTimeNum).Pluck("SUM(money) as total_money", total_money)

    如果把Db.Pluck换成Db.scan得出的就是0

    补充:golang gorm 解决mysql sum函数列有null时 报错 sconverting NULL to int64 is unsupported

    当我们查询orders表order_amount字段的和时,如果order_amount字段有null值,则gorm会报错sql:

    Scan error on column index 0, name "sum(order_amount)": converting NULL to int64 is unsupported

    var price int64

    db.Table("orders").Select("sum(order_amount)").Scan(price)

    解决方法:

    使用gorm的Pluck 从数据库查询单个列,并将结果扫描到切片,在循环取出值计算总和,这样即使有null值,也能正确计算和,不会因为sum函数的机制导致报错

    //创建一个存储查询结果的切片
    var result []int64
    var sum int64
    db.Table("orders").Pluck("order_amount",result )
    for _,v := range result{
     sum += v
     }
    

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

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

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

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

    golang gorm 计算字段和获取sum()值的实现 golang,gorm,计算,字段,和,