第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

如何將一行的 AVG 放入新列中?

如何將一行的 AVG 放入新列中?

Go
當(dāng)年話下 2023-04-17 15:04:49
大家好,我正在使用 golang 構(gòu)建一個(gè)超級(jí)簡單的 API。我有這個(gè) json 數(shù)據(jù)從 POST 請求傳遞并存儲(chǔ)在我的數(shù)據(jù)庫中。我想獲取 tts 數(shù)據(jù),它是一個(gè)整數(shù)數(shù)組,對(duì)該數(shù)組取平均值并將其放在 ttc 列中,并在 json 響應(yīng)中返回該數(shù)字。我很難做到這一點(diǎn),我們將不勝感激。下面是我的源代碼以及我的數(shù)據(jù)庫模型。我知道我必須在 postgres 中以某種方式使用 AVG() 函數(shù),但我是 postgres 的新手,所以我非常困惑。主程序package mainimport ("encoding/json""github.com/gorilla/mux""github.com/jinzhu/gorm""github.com/lib/pq""github.com/rs/cors""log""net/http"_ "github.com/jinzhu/gorm/dialects/postgres")type Resource struct {    gorm.Model    Name        string    TTS     pq.Int64Array `gorm:"type:integer[]"`    TTC int}var db *gorm.DBvar err errorfunc main() {    router := mux.NewRouter()    db, err = gorm.Open(        "postgres",        "host=localhost"+" user=postgres"+        " dbname=Shoes"+" sslmode=disable password=root")    if err != nil {        panic("failed to connect database")    }    defer db.Close()    db.AutoMigrate(&Resource{})    router.HandleFunc("/resources", GetResources).Methods("GET")    router.HandleFunc("/resources/{id}", GetResource).Methods("GET")    router.HandleFunc("/resources", CreateResource).Methods("POST")    router.HandleFunc("/resources/{id}", DeleteResource).Methods("DELETE")    handler := cors.Default().Handler(router)    log.Fatal(http.ListenAndServe(":8080", handler))}func GetResources(w http.ResponseWriter, r *http.Request) {    var resources []Resource    db.Find(&resources)    json.NewEncoder(w).Encode(&resources)}func GetResource(w http.ResponseWriter, r *http.Request) {    params := mux.Vars(r)    var resource Resource    db.First(&resource, params["id"])    json.NewEncoder(w).Encode(&resource)}func CreateResource(w http.ResponseWriter, r *http.Request) {    var resource Resource    json.NewDecoder(r.Body).Decode(&resource)    db.Create(&resource)    json.NewEncoder(w).Encode(&resource)}我想我可以做類似的事情db.Select("AVG(tts)")我只是不確定如何將該結(jié)果放入列 ttc
查看完整描述

1 回答

?
哈士奇WWW

TA貢獻(xiàn)1799條經(jīng)驗(yàn) 獲得超6個(gè)贊

由于post請求的json中已經(jīng)包含了tts_data,可以在設(shè)置到數(shù)據(jù)庫之前取平均值


sum := 0

for _, i := range tts_data {

 sum += i

}

avg := sum / len(tts_data)

// save the data in your db

rs := Ressource{Name: "name", TTS: tts_data, ttc: avg}

b := db.Create(&rs)

if b {

  // send all the resource

  json.NewEncoder(w).Encode(&rs)

  // or send only the avg

  json.NewEncoder(w).Encode(struct{avg: int}{avg: avg})

} else {

  // handle error

}


查看完整回答
反對(duì) 回復(fù) 2023-04-17
  • 1 回答
  • 0 關(guān)注
  • 128 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)