簡體   English   中英

在Django模型中通過外鍵過濾

[英]filter by foreign key in django models

假設我有以下模型:

class VKLink(models.Model):
    user_id = models.IntegerField()
    name = models.CharField(max_length=200)


class BaseComment(models.Model):
    owner = models.ForeignKey(VKLink)
    from_id = models.IntegerField(default=0)
    text = models.CharField(max_length=3000)

    def is_own(self):
        return self.from_id == self.owner.user_id

如果from_id等於鏈接user_id,則BaseComment被視為“自己的注釋”。 我想獲取所有“擁有”的BaseComments。 如何在Django模型術語中選擇它?

BaseComment.objects.filter(from_id=owner__user_id)不起作用,因為在該階段未定義owner__user_id

您可以使用F()表達式

BaseComment.objects.filter(from_id=F('owner__user_id'))

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM