使用 mysql 数据库进行没有 gorm 的狂欢

using mysql db for revel without gorm

我已将所有内容放入 app.go 并且数据库可以正确打开,但索引无法访问全局变量。全局变量似乎不是全局变量,因为如果我在 InitDB 中分配 Db 后删除它的使用,我会收到错误 "Db declared and not used"

package controllers

import (
    "database/sql"
    "fmt"

    _ "github.com/go-sql-driver/mysql"
    "github.com/revel/revel"
)

var Db *sql.DB

type App struct {
    *revel.Controller
}

func (c App) Index() revel.Result {
    if c.Params.Get("id") == "3012" {

        return c.Redirect("http://youtube.com")
    }
    fmt.Println("here is the db from index:", Db)
    return c.Render()
}

func InitDB() {

    // open db
    Db, err := sql.Open("mysql", "username:xxxxxxx@tcp(xxxxxxx:3306)/xxxx")
    if err != nil {
        revel.INFO.Println("DB Error", err)
    }
    revel.INFO.Println("DB Connected")
    //fmt.Println(Db)

}

func init() {
    revel.OnAppStart(InitDB)
}

如有任何帮助,我们将不胜感激!谢谢。

您以错误的方式声明了变量。您当前使用的方式类似于为 InitDB 范围声明一个普通变量(您正在使用 := )。

func InitDB() {

    var err error
    Db, err = sql.Open("mysql", "username:xxxxxxx@tcp(xxxxxxx:3306)/xxxx")
    if err != nil {
        revel.INFO.Println("DB Error", err)
    }
    revel.INFO.Println("DB Connected")
    //fmt.Println(Db)

}

我还建议在应用程序中创建一个名为 controllers 的文件夹来存储所有路由逻辑,如果需要,请调用 app.Db 变量

这应该有效