Запрос Django replace() с нарушением ⇐ Python
-
Гость
Запрос Django replace() с нарушением
У меня есть эта модель:
класс SettingMenus(models.Model): cat = models.ForeignKey(Setting, on_delete=models.CASCADE, linked_name="menus", null=True) index = models.SmallIntegerField(validators=[MaxValueValidator(32766)], default=0) name = models.CharField(max_length=100, null=True) путь = models.CharField(max_length=200, null=True, пусто=True) родительский = models.ForeignKey('self', null=True, Blank=True, linked_name='sub_categories', on_delete=models.CASCADE) роль = модели.ManyToManyField(UserRole, linked_name="settingMenus", пустое=True) таблицы = модели.ManyToManyField(AppModels, linked_name="setting_menus", пусто = True,) И вопрос:
nv1menus = SettingMenus.objects.filter( cat__company__name=компания, cat__application="обычный", индекс=0, role__in=request.user.groups.all() ).exclude(sub_categories__role__in=request.user.groups.all()).distinct() Как я могу нарушить sub_categories__role__in=request.user.groups.all(), который находится в исключении?
Я пробовал:
sub_categories__role__in!=request.user.groups.all()
или
не sub_categories__role__in=request.user.groups.all()
Но не работает.
Обновление:
Эта модель наследует Grops и Permission от django.contrib.auth.models
класс UserRole(Group, CommonModel): описание = models.TextField(blank=True, null=True, verbose_name="Описание группы") защита __str__(сам): вернуть свое имя. класс UserAccess (Разрешение, CommonModel): описание = models.CharField(max_length=255, null=True, Blank=True, verbose_name="Описание разрешения") защита __str__(сам): вернуть свое имя. Пользователь класса (AbstractUser): id = models.BigAutoField(primary_key=True) mobile_number = models.CharField(max_length=15, null=True, пусто=True) bio = models.TextField(verbose_name="О себе", null=True, пусто=True) группы = модели.ManyToManyField( Роль пользователя, verbose_name="Группы пользователей", пусто=Истина, связанное_имя="пользователи", связанное_имя_запроса="пользователь" ) user_permissions = models.ManyToManyField( Пользовательский доступ, verbose_name="Разрешения пользователя", пусто=Истина, связанное_имя="пользователи", связанное_имя_запроса="пользователь" ) защита __str__(сам): вернуть свое имя пользователя Здесь связана модель для модели SettingMenus
У меня есть эта модель:
класс SettingMenus(models.Model): cat = models.ForeignKey(Setting, on_delete=models.CASCADE, linked_name="menus", null=True) index = models.SmallIntegerField(validators=[MaxValueValidator(32766)], default=0) name = models.CharField(max_length=100, null=True) путь = models.CharField(max_length=200, null=True, пусто=True) родительский = models.ForeignKey('self', null=True, Blank=True, linked_name='sub_categories', on_delete=models.CASCADE) роль = модели.ManyToManyField(UserRole, linked_name="settingMenus", пустое=True) таблицы = модели.ManyToManyField(AppModels, linked_name="setting_menus", пусто = True,) И вопрос:
nv1menus = SettingMenus.objects.filter( cat__company__name=компания, cat__application="обычный", индекс=0, role__in=request.user.groups.all() ).exclude(sub_categories__role__in=request.user.groups.all()).distinct() Как я могу нарушить sub_categories__role__in=request.user.groups.all(), который находится в исключении?
Я пробовал:
sub_categories__role__in!=request.user.groups.all()
или
не sub_categories__role__in=request.user.groups.all()
Но не работает.
Обновление:
Эта модель наследует Grops и Permission от django.contrib.auth.models
класс UserRole(Group, CommonModel): описание = models.TextField(blank=True, null=True, verbose_name="Описание группы") защита __str__(сам): вернуть свое имя. класс UserAccess (Разрешение, CommonModel): описание = models.CharField(max_length=255, null=True, Blank=True, verbose_name="Описание разрешения") защита __str__(сам): вернуть свое имя. Пользователь класса (AbstractUser): id = models.BigAutoField(primary_key=True) mobile_number = models.CharField(max_length=15, null=True, пусто=True) bio = models.TextField(verbose_name="О себе", null=True, пусто=True) группы = модели.ManyToManyField( Роль пользователя, verbose_name="Группы пользователей", пусто=Истина, связанное_имя="пользователи", связанное_имя_запроса="пользователь" ) user_permissions = models.ManyToManyField( Пользовательский доступ, verbose_name="Разрешения пользователя", пусто=Истина, связанное_имя="пользователи", связанное_имя_запроса="пользователь" ) защита __str__(сам): вернуть свое имя пользователя Здесь связана модель для модели SettingMenus
Мобильная версия