服务器之家

服务器之家 > 正文

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

时间:2021-03-09 00:54     来源/作者:疯狂的鸭血

计算表lb_ytt_user_money_log 中,字段money的和

代码如下:

?
1
2
3
4
5
6
7
8
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函数的机制导致报错

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

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

原文链接:https://blog.csdn.net/weixin_45604257/article/details/105773026

标签:

相关文章

热门资讯

2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
yue是什么意思 网络流行语yue了是什么梗
yue是什么意思 网络流行语yue了是什么梗 2020-10-11
Intellij idea2020永久破解,亲测可用!!!
Intellij idea2020永久破解,亲测可用!!! 2020-07-29
背刺什么意思 网络词语背刺是什么梗
背刺什么意思 网络词语背刺是什么梗 2020-05-22
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总 2020-11-13
返回顶部