фильтрация набора запросов по результатам одного - PullRequest
1 голос
/ 13 марта 2020

Итак, у меня есть модель, называемая post, и одно из ее полей является внешним ключом для пользовательской модели, и у меня есть другая модель, называемая подписками, которая имеет 2 внешних ключа, один из которых относится к пользователю, а другой - к другой учетной записи, и я хотите отфильтровать набор запросов постов, чтобы показывать посты только тех людей, у которых есть объект подписки, где пользователь подписан на создателя поста. Мои модели выглядят так:

class post(models.Model):
    creator = models.ForeignKey(Account,blank=False,null=False,on_delete=models.CASCADE)
    ...

class subscriptions(models.Model):
    subscriber = models.ForeignKey(Account,blank=False,null=False,on_delete = models.CASCADE, related_name='subscriber')
    subscribed_to = models.ForeignKey(Account,blank=False,null=False,on_delete = models.CASCADE, related_name='subscribed_to')

Я пытался сделать это в представлениях

posts = post.objects.filter(creator__in = request.user.subscribed_to)

, но ничего не возвращалось

Это модель моего аккаунта:

class Account(AbstractBaseUser):
    email = models.EmailField(verbose_name='email', max_length=60, unique=True)
    username = models.CharField(max_length=30, unique=True)
    first_name = models.CharField(max_length=30)
    last_name = models.CharField(max_length=30)
    addresse = models.CharField(max_length=60)
    city = models.CharField(max_length=50)
    party_count = models.IntegerField(default=0)
    verified = models.BooleanField(default=False)
    profil_pic = models.ImageField(upload_to='profil_pics/',blank=True)
    birthday = models.DateField(default=date.today())
    date_joined = models.DateTimeField(verbose_name='date_joined', auto_now_add=True)
    last_login = models.DateTimeField(verbose_name='last_login', auto_now=True)
    is_admin = models.BooleanField(default=False)
    is_active = models.BooleanField(default=True)
    is_staff = models.BooleanField(default=False)
    is_superuser = models.BooleanField(default=False)

    USERNAME_FIELD = 'username'
    REQUIRED_FIELDS = ['email','first_name','last_name','addresse','birthday','city']

    objects = MyAccountManager()

    def __str__(self):
        return self.username

    def has_perm(self, perm, obj=None):
        return self.is_admin

    def has_module_perms(self,app_label):
        return True

Ответы [ 2 ]

1 голос
/ 13 марта 2020

Вы можете решить это одним запросом.

Post.objects.filter(creator__subscribed_to__subscriber=request.user)
0 голосов
/ 13 марта 2020

После некоторых исследований я нашел информацию, которая приводит к:

subs = subscriptions.objects.filter(subscriber=request.user).values_list('subscribed_to')
posts = post.objects.filter(creator__in = subs
...