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

大家好,我正在使用 golang 构建一个超级简单的 API。我有这个 json 数据从 POST 请求传递并存储在我的数据库中。我想获取 tts 数据,它是一个整数数组,对该数组取平均值并将其放在 ttc 列中,并在 json 响应中返回该数字。我很难做到这一点,我们将不胜感激。下面是我的源代码以及我的数据库模型。我知道我必须在 postgres 中以某种方式使用 AVG() 函数,但我是 postgres 的新手,所以我非常困惑。


主程序


package main


import (

"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.DB

var err error


func 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)")

我只是不确定如何将该结果放入列 ttc


当年话下
浏览 72回答 1
1回答

哈士奇WWW

由于post请求的json中已经包含了tts_data,可以在设置到数据库之前取平均值sum := 0for _, i := range tts_data { sum += i}avg := sum / len(tts_data)// save the data in your dbrs := 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}
打开App,查看更多内容
随时随地看视频慕课网APP