【问题标题】:Exclude Duplicate Objects in django queryset排除 Django 查询集中的重复对象
【发布时间】:2013-08-25 08:29:49
【问题描述】:

我有一个名为 StudentAppeared 的模型

class StudentAppeared(models.Model):
    roll_number = models.CharField(max_length=50)

假设我有以下数据

从上面的数据结果应该会显示

我如何使用 StudentAppeared 模型的 django 查询来实现这一点?

【问题讨论】:

    标签: python django django-models django-views


    【解决方案1】:

    这将返回唯一的roll_numbers 与最高关联id,按id 排序:

    from django.db.models import Max
    
    stats = (
        StudentAppeared.objects
        .values('roll_number')
        .annotate(max_id=Max('id'))
        .values_list('max_id', 'roll_number ')
        .order_by('max_id')
    )
    

    【讨论】:

      【解决方案2】:
      StudentAppeared.objects.distinct()
      

      抱歉弄错了。修好了

      【讨论】:

      • 这会返回所有五行,因为 id 是不同的。
      • 还要考虑到这不适用于 SQLite 后端(如果您正在开发中)
      猜你喜欢
      • 2021-09-09
      • 1970-01-01
      • 2016-12-29
      • 2014-04-16
      • 2016-08-09
      • 1970-01-01
      • 1970-01-01
      • 2013-04-08
      • 2017-04-12
      相关资源
      最近更新 更多