Django跟某几个字段去重MySQL

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,高可用系列 2核4GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: Django官方文档提供了使用distinct进行去重的操作,但是只支持`PostgreSQL`,具体操作可以看[官方文档],就不再过多赘述。这里写的是一种支持MySQL进行去重的操作。
  • Django官方文档提供了使用distinct进行去重的操作,但是只支持PostgreSQL,具体操作可以看官方文档,就不再过多赘述。这里写的是一种支持MySQL进行去重的操作。
  • 创建一个Book表

    from django.db import models
    
    class Book(models.Model):
        book_name = models.CharField(max_length=256, verbose_name='名称')
        category = models.CharField(max_length=256, verbose_name='类型')
        price = models.IntegerField(verbose_name="价格")
    )
  • 方案一,推荐方案,查询速度明显高于方案二。

    queryset = self.queryset.extra(where=[
            'book.id in (SELECT id FROM book WHERE category=Python GROUP BY price, book_name)'
        ])
  • 方案二,根据pricebook_name字段去重查询category为Python的数据

    queryset = Book.objects.filter(
        id__in=[i.id for i in Book.objects.raw(
            "SELECT * FROM book where category=%s GROUP BY price, book_name",
            ["Python"]
        )]
    )
  • 其实下面这一句查询条件就足够查到需要的数据,但是使用raw查出来的并不是一个QuerySet对象,想要继续在queryset的基础上继续查询,就需要再进行一次转换。

    queryset = Book.objects.raw("SELECT * FROM book where category=%s GROUP BY price, book_name", ["Python"])
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
存储 安全 网络协议
Python 教程之 Django(9)对模型中的字段进行验证
Python 教程之 Django(9)对模型中的字段进行验证
142 0
Python 教程之 Django(9)对模型中的字段进行验证
|
数据库 Python
django中的models.ManyToManyField 字段如何新增,通过Category,如何反向查询Product
django中的models.ManyToManyField 字段如何新增,通过Category,如何反向查询Product
239 10
|
存储 数据库 开发者
Django Web架构:全面掌握Django模型字段(下)
Django Web架构:全面掌握Django模型字段(下)
248 2
|
存储 数据处理 数据库
Django Web架构:全面掌握Django模型字段(上)
Django Web架构:全面掌握Django模型字段(上)
223 0
|
存储 SQL 数据处理
Django ORM实战:模型字段与元选项配置,以及链式过滤与QF查询详解
Django ORM实战:模型字段与元选项配置,以及链式过滤与QF查询详解
|
存储 数据库 Python
Python 教程之 Django(9)对模型中的字段进行验证
Python 教程之 Django(9)对模型中的字段进行验证
123 0
|
存储 前端开发 数据库
【Django学习】(十)模型序列化器_关联字段序列化
【Django学习】(十)模型序列化器_关联字段序列化
【Django学习】(十)模型序列化器_关联字段序列化
【Django学习】(九)自定义校验器_单字段_多字段校验_模型序列化器类
【Django学习】(九)自定义校验器_单字段_多字段校验_模型序列化器类
|
消息中间件 NoSQL 算法
Django 如何获取 Model 字段列表?
在平时的开发过程中,避免不了需要获取 Model 中的字段列表。
294 0
|
存储 JavaScript 前端开发
Django入门-5:模型的基本使用2-字段
Django入门-5:模型的基本使用2-字段