不知道如何使用 GORM 的 DBResolver

Can't Figure out how to use GORM's DBResolver

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 插件存在一些版本控制问题。当我 运行 上面的代码时,出现以下错误:

我在网上找不到任何原因,关于 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)},
        }))
    }
}