主页 > 知识库 > golang gorm 计算字段和获取sum()值的实现

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

热门标签:重庆庆云企业400电话到哪申请 不封卡外呼系统 上海极信防封电销卡价格 湛江crm外呼系统排名 仙桃400电话办理 地图标注免费定制店 郑州智能语音电销机器人价格 宿迁便宜外呼系统代理商 宁波语音外呼系统公司

计算表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踩过的坑

标签:辽宁 西双版纳 物业服务 安康 青海 儋州 电子产品 海南

巨人网络通讯声明:本文标题《golang gorm 计算字段和获取sum()值的实现》,本文关键词  golang,gorm,计算,字段,和,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《golang gorm 计算字段和获取sum()值的实现》相关的同类信息!
  • 本页收集关于golang gorm 计算字段和获取sum()值的实现的相关信息资讯供网民参考!
  • 推荐文章