gpt4 book ai didi

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

转载 作者:qq735679552 更新时间:2022-09-27 22:32:09 31 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章golang gorm 计算字段和获取sum()值的实现由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

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

最后此篇关于golang gorm 计算字段和获取sum()值的实现的文章就讲到这里了,如果你想了解更多关于golang gorm 计算字段和获取sum()值的实现的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com