当前位置:首页 > 文章列表 > Golang > Go问答 > 错误操作:无法调用非函数mysql.MysqlDB.Save(product).Error(类型错误的变量)

错误操作:无法调用非函数mysql.MysqlDB.Save(product).Error(类型错误的变量)

来源:stackoverflow 2024-03-24 08:06:49 0浏览 收藏

在使用 Gorm 时,调用 `mysql.MysqlDB.Save(product)` 之后的正确方法是使用 `.Error`,而不是 `.error()`。后者的调用导致了“无法调用非函数”错误。修改后的服务层代码为: ```go package service import ( "iris-seckill/db/mysql" "iris-seckill/model" ) // ...其他代码... func (p *ProductService) UpdateProduct(product *model.Product) error { return mysql.MysqlDB.Save(product).Error } ```

问题内容

谢啦。我解决了这个问题。 gorm 调用 error() 时出现问题,所以我这样写,效果很好: 套餐服务 进口 ( “iris-秒杀/db/mysql” “虹膜秒杀/模型” ) 类型 iproductservice 接口 { getproductbyid(int64) (*model.product, 错误) getallproduct()([]*model.product,错误) 按 id 删除产品(int64)错误 insertproduct(产品*型号.产品)(int64,错误) 更新产品(产品*型号.产品)错误 } 类型 productservice 结构 { } func newproductservice() iproductservice { 返回&productservice{} } func (p *productservice) getproductbyid(productid int64) (*model.product, error) { var 产品型号.product mysql.mysqldb.where("product_id = ?", productid).first(&product) 返回&产品,无 } func (p *productservice) getallproduct() (res []*model.product, err 错误) { mysql.mysqldb.find(&res) 返回 } func (p *productservice) deleteproductbyid(productid int64) 错误 { mysql.mysqldb.where("product_id = ?", productid).delete(&model.product{}) 返回零 } func (p *productservice) insertproduct(产品 *model.product) (int64, error) { mysql.mysqldb.create(产品) 返回产品.productid, nil } func (p *productservice) updateproduct(产品 *model.product) 错误 { mysql.mysqldb.save(产品) 返回零 } 但尚不清楚原因。

我在网课上模仿老师,但是在使用gorm时遇到了一个非常棘手的错误。

错误:in有效操作:无法调用非函数mysql.mysqldb.save(product).error(类型错误的变量)

控制器层的代码如下:

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.stack.imgur.com/hngih.png

错误信息如下:https://i.stack.imgur.com/sgiec.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
}

确实是我的粗心。

理论要掌握,实操不能落!以上关于《错误操作:无法调用非函数mysql.MysqlDB.Save(product).Error(类型错误的变量)》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

版本声明
本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
深入解析Go语言的函数和方法调用深入解析Go语言的函数和方法调用
上一篇
深入解析Go语言的函数和方法调用
在我的客户端上使用 Go 运行 scp 命令时遇到
下一篇
在我的客户端上使用 Go 运行 scp 命令时遇到"没有找到文件或目录"的错误
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    508次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    497次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • AI Make Song:零门槛AI音乐创作平台,助你轻松制作个性化音乐
    AI Make Song
    AI Make Song是一款革命性的AI音乐生成平台,提供文本和歌词转音乐的双模式输入,支持多语言及商业友好版权体系。无论你是音乐爱好者、内容创作者还是广告从业者,都能在这里实现“用文字创造音乐”的梦想。平台已生成超百万首原创音乐,覆盖全球20个国家,用户满意度高达95%。
    8次使用
  • SongGenerator.io:零门槛AI音乐生成器,快速创作高质量音乐
    SongGenerator
    探索SongGenerator.io,零门槛、全免费的AI音乐生成器。无需注册,通过简单文本输入即可生成多风格音乐,适用于内容创作者、音乐爱好者和教育工作者。日均生成量超10万次,全球50国家用户信赖。
    7次使用
  •  BeArt AI换脸:免费在线工具,轻松实现照片、视频、GIF换脸
    BeArt AI换脸
    探索BeArt AI换脸工具,免费在线使用,无需下载软件,即可对照片、视频和GIF进行高质量换脸。体验快速、流畅、无水印的换脸效果,适用于娱乐创作、影视制作、广告营销等多种场景。
    6次使用
  • SEO标题协启动:AI驱动的智能对话与内容生成平台 - 提升创作效率
    协启动
    SEO摘要协启动(XieQiDong Chatbot)是由深圳协启动传媒有限公司运营的AI智能服务平台,提供多模型支持的对话服务、文档处理和图像生成工具,旨在提升用户内容创作与信息处理效率。平台支持订阅制付费,适合个人及企业用户,满足日常聊天、文案生成、学习辅助等需求。
    13次使用
  • Brev AI:零注册门槛的全功能免费AI音乐创作平台
    Brev AI
    探索Brev AI,一个无需注册即可免费使用的AI音乐创作平台,提供多功能工具如音乐生成、去人声、歌词创作等,适用于内容创作、商业配乐和个人创作,满足您的音乐需求。
    14次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码