簡體   English   中英

無效操作:無法調用非函數 mysql.MysqlDB.Save(product).Error(變量類型錯誤)

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM