作为this question的后续行动,我想确定正在发生的实际错误。我做错了什么,或者这是一个错误?
f = {'groups__isnull': 'True'}
students1 = models.Student.objects.filter( **f )
students2 = models.Student.objects.filter(groups__isnull=True)
这两个查询应该相同,但不是。
供参考,我的模特:
class Student (models.Model):
user = models.ForeignKey(User, unique=True, null=False, related_name='student')
teacher = models.ForeignKey(User, null=False, related_name='students')
assignment = models.ForeignKey(LabJournal, blank=True, null=True, related_name='students')
class JournalGroup (models.Model):
title = models.CharField(null=False, max_length=256)
owner = models.ForeignKey(User, null=True, related_name='journal_groups')
members = models.ManyToManyField(Student, blank=True, related_name='groups')
答案 0 :(得分:5)
我发现查询之间存在明显差异。
{'groups__isnull': True}
永远不会等于{'groups__isnull': 'True'}
。
一个提供True作为布尔值,另一个提供为字符串。