[英]Django ORM: how count in annotation differ from count on query set?
qs = ...
qs = qs.annotate(v=Count('a', filter=Q(a__lt=5)))
a = qs.first().v
b = qs.filter(Q(a__lt=5)).count()
assert a == b # error
为什么这些方法会产生不同的结果?
从有关Count(expression, **kwargs)
的文档中:
返回通过提供的表达式相关的对象数
因此Count
专门用于计算相关对象(通过 FK 或 M2M 关系),并且对行本身的任何其他列没有多大意义。 在这种情况下,它通常会返回 1(可能取决于您的数据库返回什么值),因为总是有 1 个值。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.