【问题标题】:Django ORM Join Query IssueDjango ORM 加入查询问题
【发布时间】:2017-09-18 00:50:35
【问题描述】:

pp.pprint(AppUser.objects.filter(directory__user_id=F('id')).query.str())

('SELECT "users_appuser"."id", "users_appuser"."password", '
 '"users_appuser"."last_login", "users_appuser"."is_superuser", '
 '"users_appuser"."username", "users_appuser"."first_name", '
 '"users_appuser"."last_name", "users_appuser"."email", '
 '"users_appuser"."is_staff", "users_appuser"."is_active", '
 '"users_appuser"."date_joined", "users_appuser"."gender", '
 '"users_appuser"."age", "users_appuser"."avatar", "users_appuser"."about", '
 '"users_appuser"."city", "users_appuser"."state", '
 '"users_appuser"."location", "users_appuser"."location_updated", '
 '"users_appuser"."online", "users_appuser"."entered_offline", '
 '"users_appuser"."notifications", "users_appuser"."checkins", '
 '"users_appuser"."lock_expiration" FROM "users_appuser" INNER JOIN '
 '"chat_membershiphistory" ON ("users_appuser"."id" = '
 '"chat_membershiphistory"."user_id") WHERE '
 '"chat_membershiphistory"."user_id" = ("users_appuser"."id")')

我需要将 chat_membership 中的所有值包含到最终查询中

这是我的模型类

class MembershipHistory(TimeStampedModel):
    Active = "A"
    Offline = "O"
    Away = "X"
    NEVER_JOINED = "N"
    Locked = "L"

    _STATUSES = ((Active, 'Active'), (Offline, 'Offline'), (Away, 'Away'),
                 (Locked, 'Locked'),
                 (NEVER_JOINED, 'Never joined'))

    room = models.ForeignKey('places.Place', related_name='directory')
    user = models.ForeignKey(AppUser, related_name='directory')
    lock_expiration = models.DateTimeField(null=True,
                                           blank=True,
                                           editable=True)
    type = models.CharField(max_length=1,
                            blank=False,
                            null=False,
                            choices=_STATUSES,
                            default="A")

    class Meta:
        ordering = ('room', 'user')
        unique_together = ('room', 'user')
        verbose_name = "Member"
        verbose_name_plural = "Members"

如果我尝试 select_related,我总是会收到以下错误

Invalid field name(s) given in select_related: 'directory'. Choices are: auth_token

【问题讨论】:

    标签: django django-models django-queryset django-orm


    【解决方案1】:

    你应该使用prefetch_related

    prefetch_related('directory')
    

    【讨论】:

    猜你喜欢
    • 2012-03-28
    • 2020-05-26
    • 2014-05-19
    • 2022-01-21
    • 2014-09-04
    • 2015-10-26
    • 2021-11-15
    • 1970-01-01
    • 2015-08-15
    相关资源
    最近更新 更多