django – 在带注释的QuerySet上使用Q对象进行过滤

一个模拟测试用例:

def testCount(self):
    qs = Test.objects.all()
    qs = qs.annotate(a_count=Count('a_items'), b_count=Count('b_items'))
    for item in qs:
        print 'a_count: %d, b_count: %d' % (item.a_count, item.b_count)
    qs1 = qs.filter(Q(a_count__gt=0))
    self.assertEquals(qs1.count(), 1)
    qs2 = qs.filter(Q(a_count__gt=0) | Q(b_count__gt=0))
    self.assertEquals(qs2.count(), 1)

输出:

a_count: 1, b_count: 0
a_count: 0, b_count: 0
...
FAIL: testCount 
    self.assertEquals(qs2.count(), 1)
AssertionError: 0 != 1

为什么|运算符改变这样的行为,我该如何解决?

最佳答案 从v1.2.4开始看起来仍然是
open issue.

我想你已经测试了bug report中提供的补丁之一,或者在raw queries之前进行测试,直到它被正式修复.

点赞