gpt4 book ai didi

Django ORM。使用 AND 子句过滤多对多

转载 作者:行者123 更新时间:2023-12-04 01:56:11 25 4
gpt4 key购买 nike

具有以下模型:

class Item(models.Model):
name = models.CharField(max_length=255)
attributes = models.ManyToManyField(ItemAttribute)


class ItemAttribute(models.Model):
attribute = models.CharField(max_length=255)
string_value = models.CharField(max_length=255)
int_value = models.IntegerField()

我还有一个 Item,它有 2 个属性,'color': 'red''size': 3

如果我执行以下任何查询:

Item.objects.filter(attributes__string_value='red')
Item.objects.filter(attributes__int_value=3)

我将返回 Item,按我预期的方式工作。

但是,如果我尝试执行多个查询,例如:

Item.objects.filter(attributes__string_value='red', attributes__int_value=3)

我只想做一个 AND。这也行不通:

Item.objects.filter(Q(attributes__string_value='red') & Q(attributes__int_value=3))

输出是:

<QuerySet []>

为什么?我如何构建这样的查询以返回我的 Item,因为它具有属性 red 和属性 3

最佳答案

如果有任何用处,您可以在 Django 中链接过滤器表达式:

query = Item.objects.filter(attributes__string_value='red').filter(attributes__int_value=3')

来自DOCS :

This takes the initial QuerySet of all entries in the database, adds a filter, then an exclusion, then another filter. The final result is a QuerySet containing all entries with a headline that starts with “What”, that were published between January 30, 2005, and the current day.

使用 .filter() 但使用动态参数:

args = {
'{0}__{1}'.format('attributes', 'string_value'): 'red',
'{0}__{1}'.format('attributes', 'int_value'): 3
}

Product.objects.filter(**args)

您还可以(如果您需要ANDOR 的混合)使用Django 的Q objects .

Keyword argument queries – in filter(), etc. – are “AND”ed together. If you need to execute more complex queries (for example, queries with OR statements), you can use Q objects.

A Q object (django.db.models.Q) is an object used to encapsulate a collection of keyword arguments. These keyword arguments are specified as in “Field lookups” above.

你会得到这样的东西,而不是在那个过滤器中拥有所有的 Q 对象:

** import Q from django
from *models import Item

#assuming your arguments are kwargs
final_q_expression = Q(kwargs[1])
for arg in kwargs[2:..]
final_q_expression = final_q_expression & Q(arg);
result = Item.objects.filter(final_q_expression)

这是我没有运行过的代码,它不在我的脑海中。如果愿意,可以将其视为伪代码。

尽管如此,这并不能回答为什么您尝试过的方法不太奏效。也许它与跨越关系的查找,以及为获取这些值而连接的表有关。我建议打印 yourQuerySet.query 以可视化正在形成的 raw SQL,这可能有助于指导您了解为什么 .filter( Q() & Q ()) 不工作。

关于 Django ORM。使用 AND 子句过滤多对多,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50446466/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com