gorm数据库外键关联和级联操作

1 篇文章 0 订阅
1 篇文章 0 订阅

gorm数据库外键关联和级联操作


  1. gorm支持的外键关联:Belongs To、Has One、Has Many、Many To Many
    参考链接

  2. 预加载可以使用
    db.Preload(clause.Associations).Find(&users)
    的方式来预加载全部,单不会预加载下级的下级,如果需要可以使用
    db.Preload("Orders.OrderItems.Product").Preload(clause.Associations).Find(&users)
    方式来指定预加载内容,强制多级预加载

  3. gorm使用级联操作方式
    gorm:"constraint:OnUpdate:NO ACTION,OnDelete:RESTRICT;

  4. 级联操作表述内容如下

    级联配置OnUpdateOnDelete
    RESTRICT从表记录不存在时,主表才可以更新从表记录不存在时,主表才可以删除
    CASCADE更新主表时自动更新从表删除主表时自动删除从表
    SET NULL更新主表时自动更新从表值为NULL删除主表时自动更新从表为NULL
    NO ACTION同 RESTRICT同 RESTRICT

    注:不写默认为 RESTRICT

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值