Gorilla Mux 和 GORM 失败

Gorilla Mux and GORM fail

我按照 this tutorial 了解如何使用 PostgreSQL、Gorilla Mux 和 GORM 设置基本 API。

这是我的应用程序:

package main

import (
    "encoding/json"
    "net/http"

    "github.com/gorilla/mux"
    "github.com/jinzhu/gorm"
    _ "github.com/jinzhu/gorm/dialects/postgres"
)

var db *gorm.DB


type Ticket struct {
    gorm.Model
    InfoHash string
    Status   *int `gorm:"default:'0'"`
}


func main() {
    router := mux.NewRouter()

    db, err := gorm.Open("postgres", "host=localhost user=user dbname=db_development password=password sslmode=disable")
    db.LogMode(true)

    if err != nil {
        panic(err)
    }
    defer db.Close()

    db.AutoMigrate(&Ticket{})

    router.HandleFunc("/", TicketsIndex).Methods("GET")

    http.ListenAndServe(":3000", router)
}

func TicketsIndex(w http.ResponseWriter, r *http.Request) {
    tickets := []Ticket{}
    db.Find(&tickets)
    json.NewEncoder(w).Encode(&tickets)
}

问题是当我访问 localhost:3000 时,服务器只是停止,没有错误日志,只是停止并退出应用程序。它应该 return 作为 JSON.

存储在数据库中的门票

如果我在我的 TicketsIndex 函数中打开数据库并关闭它,它就会工作,就像这样:

func TicketsIndex(w http.ResponseWriter, r *http.Request) {
  db, err := gorm.Open("postgres", "host=localhost user=user dbname=db_development password=password sslmode=disable")
  tickets := []Ticket{}
  db.Find(&tickets)
  json.NewEncoder(w).Encode(&tickets)
  defer db.Close()
}

但我认为这不是正确的方法。我也尝试将此代码移动到主函数中并且也有效:

tickets := []Ticket{}
db.Find(&tickets)

所以我假设它可能是未正确分配的全局变量 var db *gormDB。我做错了什么?

当您键入 db, err := ... 时,您实际上是在用名为 db 的函数局部变量隐藏全局变量 var db,而不是分配给全局变量。您需要使用等号(= vs :=)来分配给已定义的变量。这也意味着您需要在赋值之前在主范围内编写 var err error,因为您不再自动从 :=.

获取声明