django filter按兩個屬性 去重

在Django中,如果你想基于兩個屬性去重,可以使用distinct()方法并結合annotate()和Count()來實現。這種方法通常用在查詢集中,尤其是在你需要統計基于某些字段的唯一值時。

示例
假設你有一個Person模型,它有兩個字段:first_name和last_name,你想要獲取所有不同的first_name和last_name組合。

模型示例
from django.db import models

class Person(models.Model):
first_name = models.CharField(max_length=100)
last_name = models.CharField(max_length=100)
使用annotate()和Count()去重
如果你只是想獲取不重復的組合數量,可以使用以下方法:

from django.db.models import Count

獲取不重復的first_name和last_name組合的數量

unique_combinations = Person.objects.values(‘first_name’, ‘last_name’).annotate(count=Count(‘id’)).order_by()
這將返回一個查詢集,其中每個條目包含一個first_name、一個last_name和一個count(即該組合出現的次數)。如果你只關心組合的唯一性而不關心計數,可以這樣做:

獲取不重復的first_name和last_name組合的列表

unique_combinations = Person.objects.values(‘first_name’, ‘last_name’).distinct().order_by()
這將返回一個去重后的列表,每個元素是一個字典,包含唯一的first_name和last_name組合。

如果你需要基于某些條件去重
如果你想要在特定條件下進行去重(例如,基于某個字段的值),你可以先進行過濾(filtering),然后應用去重:

例如,只獲取年齡大于18的唯一組合

unique_combinations = Person.objects.filter(age__gt=18).values(‘first_name’, ‘last_name’).distinct().order_by()
這樣,你就可以根據需要獲取基于兩個屬性去重的結果了。

總結
使用values(‘field1’, ‘field2’)來選擇要比較的字段。

使用.distinct()來獲取唯一組合。

使用.annotate(Count(‘id’))(或任何其他聚合函數)如果你需要計數。

使用.filter()在應用去重之前添加任何額外的條件。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/90239.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/90239.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/90239.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

PHP高級進階:突破編程邊界,開啟技術新征程

目錄一、PHP 高級函數的深度剖析1.1 回調函數的高級應用1.2 遞歸函數的優化技巧二、面向對象編程的深化2.1 抽象類與接口的實際運用2.2 設計模式在 PHP 中的實現三、PHP 與數據庫交互的高級技術3.1 數據庫連接池的使用3.2 事務處理與數據一致性四、性能優化與調試4.1 代碼性能分…

cx_Freeze python 打包詳解

優點:有時比 PyInstaller 更好處理外部 .pyd做法:安裝 cx_Freezeshpip install cx_Freeze新建 setup.py:pythonfrom cx_Freeze import setup, Executablebuild_exe_options {"packages": ["apscheduler.triggers.interval&qu…

Java字符串不可變性:從安全哲學到性能藝術的完美平衡

目錄 引言 一、什么是String的不可變性? 二、解剖String的“防彈衣”:底層實現機制 1. final的三重防御體系 2. 方法實現的精妙設計 3. 構造函數的防御性編程 三、為什么String必須不可變?設計哲學的五大支柱 1. 字符串常量池&#x…

多服務器批量發布軟件

當需要同時發布程序到多個服務器的時候,常規是通過jekins了但是喜歡了手動檔,直接寫了個簡單批量發布軟件,程序編譯發布后,直接加載配置,選擇對應的服務器,直接電機發布即可,基本可以媲美jekins…

基于.Net Core開源的庫存訂單管理系統

今天給大家推薦一套開源的庫存訂單管理系統。 項目簡介 該項目是基于Asp.Net Core Mvc開發的庫存訂單管理系統,主要實現模塊有倉庫、產品、供應商、客戶、采購訂單、銷售訂單、發貨、收貨等等,該項目是單體架構,技術棧也不是最新的&#xf…

Django學習之旅--第13課:Django模型關系進階與查詢優化實戰

在Django開發中,模型關系設計與查詢性能直接決定了系統的擴展性和效率。當業務場景從簡單的數據存儲升級為復雜的關聯分析(如訂單統計、用戶行為分析)時,基礎的模型關系和查詢方式已無法滿足需求。本節課將深入講解模型關系的高級…

簡單理解現代Web應用架構:從簡單到企業級

在開發Web應用程序時,理解如何構建一個既安全又高效的系統至關重要。本文將通過介紹從簡單的三層架構到復雜的企業級架構的演變過程,幫助您更好地理解這些概念。1. 基礎架構:React Node.js MySQL前端(React)&#xf…

修改 Lucide-React 圖標樣式的方法

修改 Lucide-React 圖標樣式的方法 使用 lucide-react 時&#xff0c;你可以通過多種方式修改圖標的樣式。以下是幾種常用的方法&#xff1a; 1. 通過 className 屬性 import { Home } from lucide-react;function MyComponent() {return <Home className"text-blue-50…

神經架構搜索革命:從動態搜索到高性能LLM的蛻變之路

本文將揭示如何通過神經架構搜索技術&#xff08;NAS&#xff09;自動發現最優網絡結構&#xff0c;并將搜索結果轉化為新一代高性能大型語言模型的核心技術。我們的實驗證明&#xff0c;該方法在同等計算資源下可實現80%的性能飛躍&#xff01;第一部分&#xff1a;神經架構搜…

【LeetCode 熱題 100】78. 子集——(解法三)位運算

Problem: 78. 子集 題目&#xff1a;給你一個整數數組 nums &#xff0c;數組中的元素 互不相同 。返回該數組所有可能的子集&#xff08;冪集&#xff09;。 解集 不能 包含重復的子集。你可以按 任意順序 返回解集。 文章目錄整體思路完整代碼時空復雜度時間復雜度&#xff1…

XCKU035?1SFVA784C Xilinx FPGA KintexUltraScale AMD

XCKU035?1SFVA784C 屬于 Xilinx Kintex UltraScale 系列&#xff0c;基于領先的 20?nm FinFET 技術制程&#xff0c;旨在為中高端應用提供卓越的性能與功耗平衡。該器件采用 784?ball Fine?pitch BGA&#xff08;SFVA784&#xff09;封裝&#xff0c;速度等級?1&#xff0…

Encore.ts:下一代高性能 TypeScript 后端框架的崛起

在 Node.js 生態系統中&#xff0c;后端框架的選擇直接影響 API 的性能、開發體驗和可維護性。近年來&#xff0c;Elysia.js、Hono、Fastify 等框架憑借各自的優化策略嶄露頭角&#xff0c;而 Encore.ts 則憑借 Rust TypeScript 混合架構&#xff0c;在性能上實現了質的飛躍。…

【IP地址】IP歸屬地查詢驅動企業實時戰略調整

動態市場感知與資源調度優化? IP歸屬地的實時分析為企業提供了市場需求的動態變化圖。 基于實時數據處理框架&#xff0c;企業可將IP歸屬地數據與用戶訪問量、轉化率等指標關聯計算&#xff0c;生成區域市場活躍度熱力圖。 當某區域IP訪問量在1小時內激增300%且停留時長提升至…

[Bug | Cursor] import error: No module named ‘data‘

import error: No module named ‘data’ Folder Structure root folder data folder dataloader.py src folder train.py <- where we try to import the dataloader.pyFailed Script ROOT_DIR Path(__file__).parent.parent os.chdir(ROOT_DIR) print(f"Using root…

#Linux權限管理:從“Permission denied“到系統安全大師

引入 Linux 作為多用戶系統&#xff0c;權限是系統安全的第一道防線。不合理的權限設置可能導致&#xff1a; 敏感文件泄露&#xff08;如數據庫密碼被讀取&#xff09;誤刪核心數據&#xff08;目錄寫權限失控&#xff09;權限漏洞被利用&#xff08;如 SUID 提權攻擊&#…

電腦重置一次對電腦傷害大嗎

在日常使用電腦的過程中&#xff0c;很多用戶或多或少都遇到過系統卡頓、軟件沖突、病毒入侵等問題。當電腦變得“越來越慢”或頻繁出錯時&#xff0c;一些用戶會考慮“重置電腦”&#xff0c;也就是將電腦恢復到出廠設置。但不少人心中也有疑問&#xff1a;重置電腦一次&#…

CSP-J系列【2024】P11229 [CSP-J 2024] 小木棍題解

題目描述小 S 喜歡收集小木棍。在收集了 n 根長度相等的小木棍之后&#xff0c;他閑來無事&#xff0c;便用它們拼起了數字。用小木棍拼每種數字的方法如下圖所示。現在小 S 希望拼出一個正整數&#xff0c;滿足如下條件&#xff1a;拼出這個數恰好使用 n 根小木棍&#xff1b;…

C# 繼承 虛方法

繼承 虛方法 &#xff08;重寫&#xff09; virtual 虛方法的關鍵字 override 重寫的關鍵字 練習&#xff1a; 繼承 繼承&#xff1a;很多類有相似的數據 相同的屬性 相同的方法 也有不同的 這個時候就可以使用繼承 讓多個類去繼承自某個具有相同數據的基類(父類) 這…

Java 堆(優先級隊列)

文章目錄優先級隊列模擬實現優先級隊列向下調整建堆向上調整建堆堆的刪除priorityQueue構造方法大根堆和小根堆的向上調整比較方法擴容面試題堆排序優先級隊列 priorityqueue&#xff1a;底層是一顆完全二叉樹 小根堆&#xff1a;根比左右孩子都小大根堆&#xff1a;根比左右…

在.NET Core API 微服務中使用 gRPC:從通信模式到場景選型

目錄 一、gRPC 基礎&#xff1a;為什么它適合微服務&#xff1f; 二、gRPC 的四種通信模式及.NET Core 實現 1. 一元 RPC&#xff08;Unary RPC&#xff09;&#xff1a;最基礎的請求 - 響應模式 2. 服務器流式 RPC&#xff08;Server Streaming RPC&#xff09;&#xff1…