# 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'])