gorm实现insert ignore into语句调用

1 篇文章 0 订阅
  1. insert into my_table values(‘1’,‘a’) :
type MyTable struct {
	x string
	y  string
}

func (tn *MyTable) Create(db *gorm.DB) error {
	return db.Create(tn).Error
}

func (tn *MyTable) TableName() string {
	return "my_table"
}
  1. insert ignore into my_table values(‘1’,‘a’):
type MyTable struct {
	x string
	y  string
}

func (tn *MyTable) Create(db *gorm.DB) error {
	return db.Clauses(clause.Insert{Modifier: "IGNORE"}).Create(tn).Error
}

func (tn *MyTable) TableName() string {
	return "my_table"
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
GORM 是一个优秀的 ORM 框架,可以很方便地和多租户系统集成。下面是一个简单的示例代码,演示了如何使用 GORM 实现多租户插件: ```go package main import ( "fmt" "github.com/jinzhu/gorm" _ "github.com/jinzhu/gorm/dialects/mysql" ) type User struct { gorm.Model Name string TenantID uint } type Tenant struct { gorm.Model Name string } type TenantAwarePlugin struct { TenantID uint } // BeforeCreate hook to set TenantID func (tap *TenantAwarePlugin) BeforeCreate(scope *gorm.Scope) error { if tap.TenantID != 0 { scope.SetColumn("TenantID", tap.TenantID) } return nil } func main() { db, err := gorm.Open("mysql", "user:password@tcp(localhost:3306)/database?charset=utf8&parseTime=True&loc=Local") if err != nil { panic("failed to connect database") } defer db.Close() db.AutoMigrate(&User{}) db.AutoMigrate(&Tenant{}) tenant1 := &Tenant{Name: "Tenant1"} db.Create(tenant1) tap := &TenantAwarePlugin{TenantID: tenant1.ID} user1 := &User{Name: "Alice"} db.Create(user1) db.Create(&User{Name: "Bob", TenantID: tenant1.ID}) var users []User db.Where("name = ?", "Alice").Find(&users) fmt.Println(users) } ``` 这个示例代码中,我们定义了两个数据模型:`User` 和 `Tenant`,并且 `User` 模型包含一个 `TenantID` 字段,用于标识该用户所属的租户。我们还定义了一个 `TenantAwarePlugin` 结构体,其中包含一个 `TenantID` 字段,用于在插入数据之前设置 `TenantID` 属性。我们在 `BeforeCreate` 钩子函数中设置 `TenantID` 属性,这样就可以自动将租户 ID 添加到插入的每一行数据中。 在主函数中,我们首先创建一个租户,并将其 ID 分配给 `TenantAwarePlugin`。然后我们使用 `gorm.Create` 函数创建两个用户,其中一个用户的 `TenantID` 字段在创建时被设置为当前租户的 ID。最后,我们查询所有名为 Alice 的用户,并输出结果。 需要注意的是,这只是一个简单的示例代码,实际应用中还需要考虑到更多的细节,例如如何处理租户 ID 不一致的情况,如何处理多租户查询等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值