【问题标题】:Django - Where IN with multiple columns/fieldsDjango - 在哪里有多个列/字段
【发布时间】:2020-04-06 14:40:25
【问题描述】:

我有一个查询需要从完全满足两列要求的表中获取。因此,如果我有 users 带有列的表,agescore

SELECT * FROM users where (age, score) IN ((5,6), (9,12), (22,44)..);

在我的网络应用程序中,我从 ajax 请求中获取这些对,而且数量可能很大。如何在 Django 中为此构造查询?

我正在开发Postgres 数据库

【问题讨论】:

  • 这里有同样的问题。 @Giorgi 解决方案会起作用,但我怀疑它的效率。如果你的 IN 列表很短,比如 2-4 条记录,我认为它会很好。

标签: django postgresql django-models django-orm


【解决方案1】:

我想出的一个解决方案是使用 django.db.models.Q 对象并构造与您编写的完全相同的查询:

ques = Q(age=5) & Q(score=6) | Q(age=9) & Q(score=12) ...
User.objects.filter(ques)

这将返回所需的查询集,但是,我会担心接收到的值的迭代性能的大小(使用 ajax)。

另一方面,我暂时不记得有更好的解决方案。如果出现问题,会更新答案。希望,这会有所帮助。

【讨论】:

  • 它将生成查询,这将做完全相同的事情。但我怀疑它的效率。例如 IN 将使用索引。这个解决方案 - 我不确定。
  • 对,我绝对同意,如果set太大,性能会出现问题。但是从问题的背景来看,我没有看到更好的方法,对吗?
  • 我使用 print(queryset.query) 检查了这个答案生成的查询。使用解释执行它(例如,解释 select * from something)。对于这两个查询,生成的解释是相同的。所以,我假设这个答案没有任何性能问题。
猜你喜欢
  • 2014-03-06
  • 2018-03-20
  • 2014-11-25
  • 2020-08-02
  • 1970-01-01
  • 2015-08-12
  • 1970-01-01
  • 1970-01-01
  • 2018-02-16
相关资源
最近更新 更多