Django-多对多关系的数据删除和新增

# models.py

# 权限表
class Rights(models.Model):
    rightName = models.CharField(max_length=30)
    level = models.CharField(max_length=5, default='0')
    path = models.CharField(max_length=20)
    pid = models.CharField(max_length=20)

# 角色表
class Roles(models.Model):
    roleName = models.CharField(max_length=20)
    description = models.CharField(max_length=20)
    rights = models.ManyToManyField(Rights)
# 获取角色对象
ro = Roles.objects.get(pk=1)

# 删除角色关联的某一个权限,可以直接传权限的id值,也可以传权限对象
ro.rights.remove(101)
ro.rights.remove(101,102,103)

# 清空角色关联的权限
ro.rights.clear()

# 给角色关联某个权限,可一次新增多个,不会清除历史数据;可以传id,也可以传对象
ro.rights.add(101)
ro.rights.add(101,102,103)

# 给角色关联多个权限,用 set 方法。可传ID,可传对象
# set方法是 先清除ro对象关联的所有权限,然后再重新关联新的值,理解成 新的 覆盖 旧的,旧的消失。
# 注意:如果 旧的值 和 新的值 ,有重复的,是保留旧的值,新的值不会新增。

ro.rights.set([101,102,103])

可以自己验证,用如下代码查看orm的sql语句。

from django.db import connection

print(connection.queries)
print(connection.queries[-1]['sql'])

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值