濮阳杆衣贸易有限公司

主頁 > 知識庫 > golang gorm 計算字段和獲取sum()值的實現(xiàn)

golang gorm 計算字段和獲取sum()值的實現(xiàn)

熱門標簽:重慶慶云企業(yè)400電話到哪申請 不封卡外呼系統(tǒng) 上海極信防封電銷卡價格 湛江crm外呼系統(tǒng)排名 仙桃400電話辦理 地圖標注免費定制店 鄭州智能語音電銷機器人價格 宿遷便宜外呼系統(tǒng)代理商 寧波語音外呼系統(tǒng)公司

計算表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函數(shù)列有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 從數(shù)據(jù)庫查詢單個列,并將結(jié)果掃描到切片,在循環(huán)取出值計算總和,這樣即使有null值,也能正確計算和,不會因為sum函數(shù)的機制導致報錯

//創(chuàng)建一個存儲查詢結(jié)果的切片
var result []int64
var sum int64
db.Table("orders").Pluck("order_amount",result )
for _,v := range result{
 sum += v
 }

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • gorm update傳入struct對象,零值字段不更新的解決方案
  • gorm操作MySql數(shù)據(jù)庫的方法
  • Go基于GORM 獲取當前請求所執(zhí)行的 SQL 信息(思路詳解)
  • Golang 使用gorm添加數(shù)據(jù)庫排他鎖,for update
  • golang Gorm與數(shù)據(jù)庫完整性約束詳解
  • golang gorm 結(jié)構(gòu)體的表字段缺省值設置方式
  • gorm FirstOrCreate和受影響的行數(shù)實例
  • 解決Go gorm踩過的坑

標簽:遼寧 西雙版納 物業(yè)服務 安康 青海 儋州 電子產(chǎn)品 海南

巨人網(wǎng)絡通訊聲明:本文標題《golang gorm 計算字段和獲取sum()值的實現(xiàn)》,本文關(guān)鍵詞  golang,gorm,計算,字段,和,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《golang gorm 計算字段和獲取sum()值的實現(xiàn)》相關(guān)的同類信息!
  • 本頁收集關(guān)于golang gorm 計算字段和獲取sum()值的實現(xiàn)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    巨野县| 佛冈县| 楚雄市| 宿迁市| 柳州市| 锦州市| 白城市| 东乡县| 长海县| 西吉县| 手机| 汝南县| 黄大仙区| 沁阳市| 泗水县| 绥阳县| 哈密市| 鲜城| 新田县| 奇台县| 旅游| 石门县| 江川县| 垣曲县| 吉木萨尔县| 喀什市| 襄樊市| 固始县| 乌兰察布市| 出国| 永嘉县| 开原市| 兴文县| 尉氏县| 简阳市| 高尔夫| 泰顺县| 江油市| 吴川市| 宁陕县| 吉水县|