使用 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 变量
这应该有效
我已将所有内容放入 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 变量
这应该有效