登录
首页 >  Golang >  Go问答

如何正确使用GORM的DBResolver功能

来源:stackoverflow

时间:2024-02-16 19:03:16 328浏览 收藏

大家好,今天本人给大家带来文章《如何正确使用GORM的DBResolver功能》,文中内容主要涉及到,如果你对Golang方面的知识点感兴趣,那就请各位朋友继续看下去吧~希望能真正帮到你们,谢谢!

问题内容

import (
    "github.com/jinzhu/gorm"
    _ "github.com/jinzhu/gorm/dialects/mysql"
    "server/config"
    "gorm.io/plugin/dbresolver"
)
    
func DB(config *config.Config) {
    var err error

    config.DB, err = gorm.Open("mysql", config.DBDSN)
    if err != nil {
        panic(err)
    }


    if !config.IsDev {
        config.DB.Use(dbresolver.Register(dbresolver.Config{
            Replicas: []gorm.Dialector{mysql.Open("mysql", config.DBDSN2)},
        }))
    }

}

我正在尝试使用 gorm 的 dbresolver 来利用我的云 sql 实例的只读副本。我认为我使用的 gorm 包和 dbresolver 插件存在一些版本控制问题。当我运行上面的代码时,出现以下错误:

  • config.db.使用未定义(类型*“github.com/jinzhu/gorm”。db没有 字段或方法使用)
  • 未定义:“github.com/jinzhu/gorm”.方言

我在网上找不到任何原因,而且关于 gorm 高级功能的在线资源也很少。如果我创建一个单独的连接,我可以轻松地让副本工作,但这样我每次与数据库交互时都需要指定数据库。 我使用以下代码来实现上面的代码:https://gorm.io/docs/dbresolver.html


解决方案


您正在使用 gorm 的 v1 导入路径,但 dbresolver 是 v2 功能。 您需要使用:

  • "gorm.io/gorm" 主导入包
  • "gorm.io/driver/mysql" 用于驱动程序导入
  • gorm.openmysql.open 用于创建连接。
  • v2 基本上向后兼容,但您需要确保所有旧代码都经过测试才能在新版本上运行。
import (
    "gorm.io/gorm"
    "gorm.io/driver/mysql"
    "gorm.io/plugin/dbresolver"
    "server/config"
)
    
func DB(config *config.Config) {
    var err error

    config.DB, err := gorm.Open(mysql.Open(config.DBDSN), &gorm.Config{})
    if err != nil {
        panic(err)
    }


    if !config.IsDev {
        config.DB.Use(dbresolver.Register(dbresolver.Config{
            Replicas: []gorm.Dialector{mysql.Open("mysql", config.DBDSN2)},
        }))
    }
}

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《如何正确使用GORM的DBResolver功能》文章吧,也可关注golang学习网公众号了解相关技术文章。

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>