如何将一行的AVG放到一个新的列中?
问题:如何将一行的AVG放到一个新的列中? 大家好,我正在使用 golang 构建一个超级简单的 API。我有这个从 POST 请求传递的 json 数据并存储在我的数据库中。我想获取 tts 数据,它是一个整数数组并平均该数组并将其放在 ttc 列中,并在 json 响应中返回该数字。我很难做到,任何帮助都将不胜感激。我的源代码以及我的数据库模型如下。我知道我必须在 postgres 中以某种方
·
问题:如何将一行的AVG放到一个新的列中?
大家好,我正在使用 golang 构建一个超级简单的 API。我有这个从 POST 请求传递的 json 数据并存储在我的数据库中。我想获取 tts 数据,它是一个整数数组并平均该数组并将其放在 ttc 列中,并在 json 响应中返回该数字。我很难做到,任何帮助都将不胜感激。我的源代码以及我的数据库模型如下。我知道我必须在 postgres 中以某种方式使用 AVG() 函数,但我是 postgres 的新手,所以我非常困惑。
main.go
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)
}
func DeleteResource(w http.ResponseWriter, r *http.Request) {
params := mux.Vars(r)
var resource Resource
db.First(&resource, params["id"])
db.Delete(&resource)
var resources []Resource
db.Find(&resources)
json.NewEncoder(w).Encode(&resources)
}
我想我可以做类似的事情
db.Select("AVG(tts)")
我只是不确定如何将该结果放在 ttc 列中
解答
由于post请求的json中已经包含tts_data
,所以可以先取平均值再存入数据库
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
}
更多推荐
目录
所有评论(0)