Получить все объекты, определенные отношениями Django ManyToManyField

Сайт, который я создаю, позволяет пользователям создавать «сообщения» и имеет концепцию, похожую на Twitter, о подписанных пользователях. Для данного пользователя я хотел бы показать все сообщения пользователей, на которых они подписаны.

Вот мои упрощенные модели:

class User
    # a standard django.contrib.auth user model

class UserProfile(models.Model):
    # my AUTH_PROFILE_MODULE for django-profiles
    user = models.ForeignKey(User, unique=True)
    following = models.ManyToManyField('self', symmetrical=False, related_name="followed_by")

class Posts(models.Model):
    user = models.ForeignKey(User)
    post = models.TextField()

Вопрос: Как создать набор запросов всех объектов Post из пользователей, на которых подписан данный пользователь?

Думаю, я усложнил задачу, создав отношения "следовать" в UserProfile, а это не модель с отношениями ForeignKey с сообщениями.

ОБНОВЛЕНИЕ! Вот ответ:

Posts.objects.filter(user__userprofile__in=UserProfile.objects.get(user=your_user_object).following.all())
5
задан mitchf 26 November 2010 в 20:27
поделиться