環境
- macOS High Sierra
- sqliteではなく、mysql
- gorpではなく、gorm
参考: Go言語フレームワークRevelとPaizaCloudを使って10分でWebサービスを作る方法 - paiza開発日誌
booking tutorialの途中でエラーが出ました。
https://github.com/revel/examples/tree/master/booking
ERROR 18:33:28 watcher.go:270: Build detected an error error="Go Compilation Error (in app/controllers/gorm.go:31): undefined: sql"
経緯
controllers/app.goでgetUser を定義しようとしたら怒られました。
まず手始めに、Txnが定義されていないと言われたので、(以下)
ERROR 18:18:26 watcher.go:270: Build detected an error error="Go Compilation Error (in app/controllers/app.go:26): c.Txn undefined (type Application has no field or method Txn)"
controllers/gorm.go
に
type Transactional struct {
*revel.Controller
Txn *sql.Tx
}
を記述(あっているかわかりません。。。。)
これで、Txnを定義したと思ったら
一番上のエラーが出てきました。
sqlが見当たりませんと言われました。
Txn *sql.Txこの部分ですね。
どこかに、sqlの定義文が必要なのか、それともpackageをimportする必要があるのか?
それとも、他に原因があるのか?
controllers/gorm.go
package controllers
import (
_ "github.com/go-sql-driver/mysql"
"github.com/jinzhu/gorm"
"github.com/revel/revel"
"booking/app/models"
"log"
)
type Transactional struct {
*revel.Controller
Txn *gorm.Tx
}
var DB *gorm.DB
//dbの設定
func InitDB() {
dbInfo, _ := revel.Config.String("db.info")
db, err := gorm.Open("mysql", dbInfo)
if err != nil {
log.Panicf("Failed gorm.Open: %v\n", err)
}
db.DB()
db.AutoMigrate(&models.Booking{})
db.AutoMigrate(&models.Hotel{})
db.AutoMigrate(&models.User{})
DB = db
}
controllers/app.go
package controllers
import (
"github.com/revel/revel"
"booking/app/models"
"booking/app/routes"
)
type Application struct {
*revel.Controller
}
func (c Application) Index() revel.Result {
if c.connected() != nil {
return c.Redirect(routes.Hotels.Index())
}
c.Flash.Error("Please log in first")
return c.Render()
}
func (c Application) connected() *models.User {
if c.ViewArgs["user"] != nil {
return c.ViewArgs["user"].(*models.User)
}
if username, ok := c.Session["user"]; ok {
return c.getUser(username.(string))
}
return nil
}
func (c Application) getUser(username string) (user *models.User) {
user = &models.User{}
_, err := c.Session.GetInto("fulluser", user, false)
if user.Username == username {
return user
}
err = c.Txn.SelectOne(user, c.Db.SqlStatementBuilder.Select("*").From("User").Where("Username=?", username))
if err != nil {
if err != sql.ErrNoRows {
//c.Txn.Select(user, c.Db.SqlStatementBuilder.Select("*").From("User").Limit(1))
count, _ := c.Txn.SelectInt(c.Db.SqlStatementBuilder.Select("count(*)").From("User"))
c.Log.Error("Failed to find user", "user", username, "error",err, "count", count)
}
return nil
}
c.Session["fulluser"] = user
return
}
func (c Application) Register() revel.Result {
return c.Render()
}
全体のコードが必要なら挙げます。
このTxnメソッドが邪魔なんだと思っています。
これは、gorpのメソッドなので、gormでは使用できないのではないか?とも思っています。
では、gormではどのようにすれば動くのでしょうか?