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
,因为您不再自动从 :=
.
获取声明
我按照 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
,因为您不再自动从 :=
.