has_many :through VS has_and_belongs_to_many

user role

has_and_belongs_to_many

  role.destroy:  关联表user_roles先删除记录,再role删除。

has_many :through 

  user.roles = Role.all

  user.roles 接收的是一个集合,Role.first不是集合,如果想将user.roles 设为Role.first,可以

    user.roles = []    user.roles << Role.first  或   user.roles = Role.where(:id => 3或:id=>[1,2,3])假设是3

  role.destroy:  如果在user/role不配置has_many :dependent => :destroy 只删除role不删除中间表,配置了会删除role,和中间表,但关联的user不会被删除   has_and_belongs_to_many不需要配置就可以直接删除相应内容

 

多对多删除操作:都是先删除关联,再删除自身,不删除关联对象 

转载于:https://www.cnblogs.com/znsongshu/p/6183628.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值