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

}

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

本文标题: golang gorm 计算字段和获取sum()值的实现

本文地址: http://www.cppcns.com/jiaoben/golang/370318.html

goland gorm分组查询统计_golang gorm 计算字段和获取sum()值的实现相关推荐

  1. 20150218【改进Poll定时查询】IMX257实现GPIO-IRQ中断按键获取键值驱动程序

    [改进Poll定时查询]IMX257实现GPIO-IRQ中断按键获取键值驱动程序 2015-02-18 李海沿 按键驱动程序中,如果不使用read函数中使程序休眠的,而是还是使用查询方式的话,可以使用 ...

  2. sqlalchemy case when分组查询统计

    1.需求 根据过滤条件将设备按升级状态分组,统计总数和各个状态的数量. 2.原始数据 3.原生sql语句 select count(*) as "total",sum(case w ...

  3. MySQL分组查询统计每个选项的数量

    帮客户做个问卷调查,最后需要统计每道问题的每个选项的数量.思路是先按问题分组,然后使用case语句区分每个选项,然后做统计. SQL语句如下: SELECTexamQuestionId,SUM(CAS ...

  4. mysql分组查询统计求和

    说明 根据terminal_id中相同的值求和统计出cnt的值 select t.terminal_id,sum(t.cnt) from table_name t group by t.termina ...

  5. oracle多条件分组查询数量_ORACLE分组查询和统计等

    select flow_id,rw from (select t.flow_id ,rownum as rw from apex_030200.wwv_flow_list_templates t)  ...

  6. access设计视图打不开_15、ACCESS总计查询(分组查询)设计(ACCESS图解操作系列)...

    操作要求: 在利用ACCESS数据库"教学管理钟老师课堂.accdb"中数据表,完成如下查询. 1.创建一总计查询"学生合格门数-所获学分-总计查询".以学生. ...

  7. 一个分组查询引发的思考

    一个分组查询引发的思考 我们在看项目代码或者SQL语句时, 往往会看到很多非常复杂的业务或者SQL 那么问题来了. 复杂SQL是如何写成的? 下面通过一个数据展示的需求来体会到复杂的SQL是如何书写的 ...

  8. mysql分组函数按月份差,学习猿地-mysql如何按月份分组查询

    mysql按月份分组查询的方法:根据format字符串格式化date值,语法为[DATE_FORMAT(date,format)],其中[%M ]为月的名字. mysql按月份分组查询的方法:sele ...

  9. mysql按月份分组查询_mysql如何按月份分组查询

    mysql按月份分组查询的方法:根据format字符串格式化date值,语法为[DATE_FORMAT(date,format)],其中[%M ]为月的名字. mysql按月份分组查询的方法:sele ...

最新文章

  1. Gdiplus中实现双Buffer绘图
  2. Linux oracle数据库自动备份自动压缩脚本代码
  3. svn: E215004: Authentication failed
  4. 持续提高 Android 应用的安全性与性能
  5. RabbitMQ和Kafka的区别
  6. 使用Jedis出现Connection refused的解决方案
  7. 解答网友提问:如何构建动态表达式实现高级查询服务
  8. Eclipse导入他人的Maven工程报错
  9. 解决firefox不能安装Flash插件
  10. 找到replication相关的作业和sql 语句
  11. PowerDesigner教程系列(五)概念数据模型
  12. EVENT ADJUST_SCN 说明 [30681.1]
  13. vue+nodejs+element 实现drawio绘图效果
  14. 最新即时通讯聊天安卓APP源码+全开源/Uniapp内核
  15. 2019计算机二级vb考试大纲,2019年全国计算机二级VB试题
  16. gmsk的matlab仿真,MSKGMSK 导师传给我的关于MSK和GMSK的一些相关MATLAB仿真源码 - 下载 - 搜珍网...
  17. iOS10访问通讯录、相册等隐私权限设置
  18. 如何使用AE制作文字破碎动画?制作ae破碎文字特效教程分享
  19. 为什么会患糖尿病足?可能与这5种原因有关
  20. 彻底掌握 Promise-原生Promise的实现(二) Promise的链式调用

热门文章

  1. SQL 安装在DC上的问题
  2. XXE漏洞 解决方案(JAVA版本)
  3. 大幅广告显示隐藏效果
  4. 一加神秘新机入网:搭载天玑8100 首发长寿版150W超级闪充
  5. 这个“十一”长假,你是背“锅”出行吗?
  6. 董明珠再谈“格力10年免费包修”政策:没企业敢跟,实力的象征
  7. 纯电动SUV哪吒U Pro即将上线:最高续航610公里
  8. 腾讯音乐Q3财报多点开花,属于数字音乐时代的新浪潮已至
  9. 蚂蚁集团:中签号码共有701696个
  10. 低价iPhone 12彻底没戏了?苹果严控渠道:给拼多多等电商供货罚款40万元/台