运用Q对象我有以下代码:在列表理解
def get_elements(self, obj):
book_elements = Element.objects.filter(book__pk=obj.id)
elements = Element.objects.filter((Q(book__pk=obj.id) | Q(theme__pk=obj.theme_id)), ~Q(pk__in = [o.element_id for o in book_elements if o.element_id]))
serializer = GetElementSerializer(elements, context=self.context, many=True)
元素变量是使用Q对象实现的查询。但是,Q(book__pk=obj.id)
和book_elements
引用了完全相同的一组值。如何在列表理解中引用Q(book__pk=obj.id)
以避免必须运行2个查询。像下面这样:
def get_elements(self, obj):
elements = Element.objects.filter((Q(book__pk=obj.id) | Q(theme__pk=obj.theme_id)), ~Q(pk__in = [o.element_id for o in Q(book__pk=obj.id) if o.element_id]))
serializer = GetElementSerializer(elements, context=self.context, many=True)
我的元模型的要求:
class Element(models.Model):
name = models.CharField(max_length=100)
pub_date = models.DateTimeField('date published', auto_now_add=True)
mod_date = models.DateTimeField('modified date', auto_now=True)
book = models.ForeignKey(Book, blank=True, null=True, related_name='elements')
book_part = models.ForeignKey(BookPart)
theme = models.ForeignKey(Theme, blank=True, null=True, related_name='elements')
element = models.ForeignKey('self', blank=True, null=True, related_name='parent')
def __str__(self):
return self.name
任何帮助表示赞赏!
如果我理解你的查询正确无误(用简单的英语),你正在做 - 将所有元素都带到book_id或theme_id中,但不包括与书相关的所有元素。我对么? – karthikr 2015-03-31 20:45:30
你几乎没错。我想要的是 - 将所有元素与book_id或theme_id相提并论,这些元素与本书的书籍ID和主题ID相等,不包括与本书中另一个元素具有FK关系的元素。 – Zach 2015-03-31 21:22:31
你可以添加你的模型吗? – schillingt 2015-03-31 21:25:22