[英]invalid operation: cannot call non-function mysql.MysqlDB.Save(product).Error (variable of type error)
谢啦。 我解决了这个问题。
Gorm 调用 Error() 时出现问题,所以我这样写,它运行良好:
package service import ( "iris-seckill/db/mysql" "iris-seckill/model" ) type IProductService interface { GetProductByID(int64) (*model.Product, error) GetAllProduct() ([]*model.Product, error) DeleteProductByID(int64) error InsertProduct(product *model.Product) (int64, error) UpdateProduct(product *model.Product) error } type ProductService struct { } func NewProductService() IProductService { return &ProductService{} } func (p *ProductService) GetProductByID(productID int64) (*model.Product, error) { var product model.Product mysql.MysqlDB.Where("product_id =?", productID).First(&product) return &product, nil } func (p *ProductService) GetAllProduct() (res []*model.Product, err error) { mysql.MysqlDB.Find(&res) return } func (p *ProductService) DeleteProductByID(productID int64) error { mysql.MysqlDB.Where("product_id =?", productID).Delete(&model.Product{}) return nil } func (p *ProductService) InsertProduct(product *model.Product) (int64, error) { mysql.MysqlDB.Create(product) return product.ProductID, nil } func (p *ProductService) UpdateProduct(product *model.Product) error { mysql.MysqlDB.Save(product) return nil }
但目前尚不清楚为什么。
我在模仿网课老师,但是在使用GORM的时候遇到了一个很棘手的错误。
错误: invalid operation: cannot call non-function mysql.MysqlDB.Save(product).Error (variable of type error)
controller层代码如下:
package controller
import (
"iris-seckill/model"
"iris-seckill/service"
"github.com/kataras/iris/v12"
"github.com/kataras/iris/v12/mvc"
)
type ProductController struct {
Ctx iris.Context
ProductService service.IProductService
}
func (p *ProductController) GetAll() (mvc.View, error) {
products, err := p.ProductService.GetAllProduct()
if err != nil {
return mvc.View{}, err
}
return mvc.View{
Name: "product/view.html",
Data: iris.Map{
"products": products,
},
}, nil
}
func (p *ProductController) PostUpdate() {
product := &model.Product{}
p.Ctx.Request().ParseForm()
err := p.ProductService.UpdateProduct(product)
if err != nil {
p.Ctx.Application().Logger().Debug(err)
}
p.Ctx.Redirect("/product/all")
}
服务层代码如下:
package service
import (
"iris-seckill/db/mysql"
"iris-seckill/model"
)
type IProductService interface {
GetProductByID(int64) (*model.Product, error)
GetAllProduct() ([]*model.Product, error)
DeleteProductByID(int64) error
InsertProduct(product *model.Product) (int64, error)
UpdateProduct(product *model.Product) error
}
type ProductService struct {
}
func NewProductService() IProductService {
return &ProductService{}
}
func (p *ProductService) GetProductByID(productID int64) (*model.Product, error) {
var product model.Product
err := mysql.MysqlDB.Where("product_id = ?", productID).First(&product).Error()
if err != nil {
return nil, err
}
return &product, nil
}
func (p *ProductService) GetAllProduct() (res []*model.Product, err error) {
err = mysql.MysqlDB.Find(&res).Error()
return
}
func (p *ProductService) DeleteProductByID(productID int64) error {
err := mysql.MysqlDB.Where("product_id = ?", productID).Delete(&model.Product{}).Error()
return err
}
func (p *ProductService) InsertProduct(product *model.Product) (int64, error) {
err := mysql.MysqlDB.Create(product).Error()
if err != nil {
return 0, err
}
return product.ProductID, nil
}
func (p *ProductService) UpdateProduct(product *model.Product) error {
err := mysql.MysqlDB.Save(product).Error()
return err
}
主要的main.go
代码如下:
package main
import (
"context"
"iris-seckill/backend/web/controller"
"iris-seckill/conf"
"iris-seckill/db/mysql"
"iris-seckill/service"
"github.com/kataras/iris/v12"
"github.com/kataras/iris/v12/mvc"
logging "github.com/sirupsen/logrus"
)
func main() {
app := iris.New()
app.Logger().SetLevel("debug")
tmplate := iris.HTML("./backend/web/assets", ".html").Layout("share/layout").Reload(true)
app.RegisterView(tmplate)
app.HandleDir("/assets", "./backend/web/assets")
app.OnAnyErrorCode(func(ctx iris.Context) {
ctx.ViewData("message", ctx.Values().GetStringDefault("message", "访问的页面出错!"))
ctx.ViewLayout("")
ctx.View("share/error.html")
})
ctx, cancel := context.WithCancel(context.Background())
defer cancel()
productService := service.NewProductService()
productParty := app.Party("/product")
productApp := mvc.New(productParty)
productApp.Register(ctx, productService)
productApp.Handle(new(controller.ProductController))
err := app.Run(
iris.Addr(conf.IrisAddr),
iris.WithoutServerError(iris.ErrServerClosed),
iris.WithOptimizations,
)
if err != nil {
logging.Info(err)
}
}
func init() {
conf.Init("./conf/config.ini")
mysql.Init()
}
工程目录结构如下: https://i.imgur.com/FlYIOdD.png
错误信息如下: https://i.imgur.com/Ycl5THQ.png
MysqlDB 工作并通过了测试。
真不知道怎么回事,连debug都报错。
我希望有人能帮助我,我很感激你能给我的任何帮助。谢谢
顺便说一句,我和视频老师唯一的区别是老师自己写了数据库层操作,我用的是Gorm,不知道是不是重点。
在 Gorm 中,注意.Error
和.Error()
的区别。
为了解决这个问题,编辑服务层的代码如下:
package service
import (
"iris-seckill/db/mysql"
"iris-seckill/model"
)
type IProductService interface {
GetProductByID(int64) (*model.Product, error)
GetAllProduct() ([]*model.Product, error)
DeleteProductByID(int64) error
InsertProduct(product *model.Product) (uint, error)
UpdateProduct(product *model.Product) error
}
type ProductService struct {
}
func NewProductService() IProductService {
return &ProductService{}
}
func (p *ProductService) GetProductByID(id int64) (*model.Product, error) {
var product model.Product
err := mysql.MysqlDB.Where("id = ?", id).First(&product).Error
return &product, err
}
func (p *ProductService) GetAllProduct() (res []*model.Product, err error) {
err = mysql.MysqlDB.Find(&res).Error
return
}
func (p *ProductService) DeleteProductByID(id int64) error {
err := mysql.MysqlDB.Where("id = ?", id).Delete(&model.Product{}).Error
return err
}
func (p *ProductService) InsertProduct(product *model.Product) (uint, error) {
err := mysql.MysqlDB.Create(product).Error
return product.ID, err
}
func (p *ProductService) UpdateProduct(product *model.Product) error {
err := mysql.MysqlDB.Save(product).Error
return err
}
这真的是我的粗心。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.