不知道如何使用 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 插件存在一些版本控制问题。当我 运行 上面的代码时,出现以下错误:
- config.DB.Use undefined (type *"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.Open
与 mysql.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)},
}))
}
}
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.Use undefined (type *"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.Open
与mysql.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)},
}))
}
}