我正在尝试在GORM中实现“插入忽略”。我尝试过Create()
,但我找不到添加Ignore
的方法。我也试过Clause in Gorm
DB.Clauses(clause.Insert{Modifier: "IGNORE"}).Create(&user)`.
然而,我得到了一个错误,说Clauses undefined (type *"github.com/jinzhu/gorm".DB has no field or method Clauses)
。
我也尝试使用DB.Raw()
,但我不知道如何每次更改表,因为我的数据库中有这么多表。例如
DB.Raw("INSERT IGNORE INTO A/B/C/.. ... ...")`.
我有很多表将通过这个函数,每次我可能会插入到不同的表中。
我想知道是否有人在GORM中有使用Insert Ignore
的经验。谢谢!
发布于 2020-08-19 23:40:46
大家好,欢迎来到StackOverflow。
我认为您正在使用gorm v1
。但是你需要的代码在gorm v2
上。
首先,您必须通过在终端上运行以下命令来获取Gorm v2
和MySQL dialector
。
go get -u gorm.io/gorm // get gorm v2
go get -u gorm.io/driver/mysql // get dialector of mysql from gorm
然后你可以使用gorm的Clauses
。
这段代码将为您工作。
import (
"gorm.io/gorm"
"gorm.io/driver/mysql"
)
func main(){
db, err := gorm.Open(mysql.Open(MYSQL_CONNECTION_STRING), &gorm.Config{})
if err != nil {
fmt.Println(err.Error())
}else{
db.Clauses(clause.Insert{Modifier: "IGNORE"}).Create(&user)
}
}
发布于 2021-05-13 19:36:02
对于Gorm v2
来说,答案很明确:Clause in Gorm。
对于Gorm v1
,您可以在Gorm v1
的测试中找到解决方案。请参阅:https://github.com/jinzhu/gorm/blob/master/create_test.go#L285
if DB.Dialect().GetName() == "mysql" && DB.Set("gorm:insert_modifier", "IGNORE").Create(&user).Error != nil {
t.Error("Should ignore duplicate user insert by insert modifier:IGNORE ")
}
我多次遇到这个问题,因为我们团队中的许多人仍然有很多使用Gorm v1
的代码……
https://stackoverflow.com/questions/63479636
复制相似问题