使用.distinct()时,Django ORM多次返回相同的值

Ann*_*nna 3 python django django-orm

.distinct()在一组对象上使用时,相同的值被反复重复,这违背了使用的目的.distinct()

我正在研究的项目的一个例子:

In [5]: Section.objects.filter(module=15).values('section').distinct()
Out[5]: [{'section': '1'}, {'section': '2'}, {'section': '2'}, {'section': '2'}, {'section': '2'}, {'section': '2'}, {'section': '2'}, {'section': '2'}, {'section': '2'}, {'section': '2'}, {'section': '2'}, {'section': '2'}, {'section': '2'}, {'section': '2'}, {'section': '2'}, {'section': '2'}, {'section': '2'}, {'section': '2'}, {'section': '2'}, {'section': '2'}, '...(remaining elements truncated)...']
Run Code Online (Sandbox Code Playgroud)

为什么它返回每个值而不是仅返回不同的值?

供参考,这是我的模型:

class Section(models.Model):
    module = models.ForeignKey(Module, on_delete=models.CASCADE)
    title = models.CharField(max_length=400)
    section = models.CharField(max_length=3)
    topic = models.CharField(max_length=3)
    subtopic = models.CharField(max_length=3)
    subsubtopic = models.CharField(max_length=3)
    language = models.CharField(max_length=2)
    def __str__(self):
        return self.sectionid() + " - " + self.title
    def sectionid(self):
        return self.module.moduleid + ": " + self.justsectionid()
    def justsectionid(self):
        return self.section + "." + self.topic + "." + self.subtopic + \
        self.subsubtopic + "-" + self.language
    class Meta:
        ordering = ['section', 'topic', 'subtopic', 'subsubtopic', 'language']
Run Code Online (Sandbox Code Playgroud)

Ann*_*nna 7

.distinct()如果使用元排序,Django ORM会出现此问题.为了使其按预期工作,您需要将排序重置为默认值.您可以通过以下空白呼叫执行此操作.order_by():

In [6]: Section.objects.filter(module=15).order_by().values('section').distinct()
Out[6]: [{'section': '1'}, {'section': '2'}, {'section': '3'}]
Run Code Online (Sandbox Code Playgroud)