[英]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.