golang gorm 计算字段和获取sum()值的实现-kb88凯时官网登录

时间:2020-12-19
阅读:
免费资源网 - https://freexyz.cn/

计算表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
 }

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

免费资源网 - https://freexyz.cn/
返回顶部
顶部
网站地图