亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

為選擇查詢傳遞可變參數

為選擇查詢傳遞可變參數

Go
慕村9548890 2021-12-06 16:36:24
我正在嘗試按如下方式構建查詢,這里我使用的是 gorp。func GetAgregatedDownloadsFromTo(constrains Constrains) [] dao.NameValue {    dbMap := utils.GetDBConnection("radsummary");    defer dbMap.Db.Close()    var totalDailyDownloads[] NameValue    query := "SELECT SUM(outputoctets) as value ,date as name FROM dailyacct where date >= ? AND date < ? "    if len(constrains.LocationGroups) > 0 {        query = query + " AND calledstationid=? "        for i := 1; i< len(constrains.LocationGroups); i++ {            query = query + " OR calledstationid=? "        }        query = query + " group by date"        print(query)        _, err := dbMap.Select(&totalDailyDownloads, query, constrains.From, constrains.To, constrains.LocationGroups...)        if err != nil {            panic(err.Error()) // proper error handling instead of panic        }    }    return totalDailyDownloads}type Constrains struct {    From string `json:"from"`    To string   `json:"to"`    LocationGroups []string    `json:"locationgroups"`}查詢構造基于 constrains.LocationGroups 的長度發生。我遇到的麻煩是將可變數量的 args 傳遞給 Select 查詢,一旦我給出了 constrains.LocationGroups... 作為選擇查詢參數,它會引發編譯器錯誤too many arguments in call to dbMap.Select有沒有可能達到這種要求?。感謝您的投入。
查看完整描述

1 回答

?
MM們

TA貢獻1886條經驗 獲得超2個贊

找到了一個基于Pass string slice to variadic empty interface 參數的答案


以下是完成任務的更新代碼


func GetAgregatedDownloadsFromTo(constrains dao.Constrains) [] dao.NameValue {

    dbMap := utils.GetDBConnection("radsummary");

    defer dbMap.Db.Close()

    var totalDailyDownloads[] dao.NameValue

    query := "SELECT SUM(outputoctets) as value ,date as name FROM dailyacct where date >= ? AND date < ? "


    if len(constrains.LocationGroups) > 0 {

        args := make([]interface{}, len(constrains.LocationGroups)+2)

        args[0] = constrains.From

        args[1] = constrains.To

        for index, value := range constrains.LocationGroups { args[index+2] = value }


        query = query + " AND calledstationid=? "

        for i := 1; i< len(constrains.LocationGroups); i++ {

            query = query + " OR calledstationid=? "

        }

        query = query + " group by date"

        print(query)

        _, err := dbMap.Select(&totalDailyDownloads, query, args...)

        if err != nil {

            panic(err.Error()) // proper error handling instead of panic

        }

    }

    return totalDailyDownloads

}

在這里,我不得不將字符串切片轉換為接口切片。


查看完整回答
反對 回復 2021-12-06
  • 1 回答
  • 0 關注
  • 189 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號