Django筆記十七之group by 分組用法總結

来源:https://www.cnblogs.com/hunterxiong/archive/2023/04/08/17297775.html
-Advertisement-
Play Games

一個非常簡單的小項目。 看到了楊旭大佬的教學視頻,自己跟著實現了一下,完善了一下游戲邏輯。 通過空格鍵進行控制。 游戲中可按 P 鍵 暫停/恢復 游戲 項目結構 · ├── Cargo.lock ├── Cargo.toml ├── src/ │ ├── main.rs │ ├──bird/ │ │ ...


本文首發於微信公眾號:Hunter後端
原文鏈接:Django筆記十七之group by 分組用法總結

這篇筆記介紹 Django 裡面 model 的 group by 對應的一些操作。

用到的 Model 如下:

class TestModel(models.Model):
    num = models.IntegerField()
    user_id = models.IntegerField()
    create_date = models.DateField()

我們寫入幾條數據:

TestModel.objects.create(num=78, user_id=1, create_date="2022-01-01")
TestModel.objects.create(num=99, user_id=1, create_date="2022-01-01")
TestModel.objects.create(num=87, user_id=1, create_date="2022-01-08")

TestModel.objects.create(num=66, user_id=2, create_date="2022-01-01")
TestModel.objects.create(num=54, user_id=2, create_date="2022-01-08")
TestModel.objects.create(num=77, user_id=2, create_date="2022-01-16")

本篇筆記的目錄如下:

  1. distinct 單個欄位
  2. distinct 多個欄位
  3. count 欄位去重後總數
  4. sum 某個欄位總和
  5. group by 分組統計 count
  6. group by 分組統計 max
  7. group by 分組統計 sum
  8. group by 分組統計 count + distinct

1、distinct 單個欄位

現在我們需要 user_id 這個欄位進行去重處理,獲取一個去重後的 user_id 的列表

使用 SQL 的話,大致如下:

select distinct user_id from blog_test;

使用 QuerySet 語句則是:

TestModel.objects.values_list("user_id", flat=True).distinct()

2、distinct 多個欄位

假設需要對 user_id 和 create_date 這兩個欄位做去重處理,

使用 SQL 語句如下:

select distinct user_id, create_date from blog_test;

對應的 QuerySet 語句:

TestModel.objects.values("user_id").distinct()

3、count 欄位去重後總數

比如我們想查看 2022-01-01 這天有多少不同 user_id 值的數據

select count(distinct user_id) from blog_test where create_date = '2022-01-01';

對應的 QuerySet 為:

TestModel.objects.filter(create_date='2022-01-01').values("user_id").distinct().count()

4、sum 某個欄位總和

我們想查看 2022-01-01 這天 num 欄位的數據的總和有多少:

select sum(num) from blog_test where create_date = '2022-01-01';

Django 語句:

from django.db.models import Sum

TestModel.objects.filter(create_date='2022-01-01').aggregate(sum_num=Sum('num'))

# 返回值為 
# {'sum_num': 243}

5、group by 分組統計 count

按照日期統計 user_id 的總數:

select create_date, count(user_id) from blog_test group by create_date;

Django 語句:

from django.db.models import Count

TestModel.objects.values("create_date").annotate(count=Count("user_id"))

6、group by 分組統計 max

按照日期計算每一天最大的 num 的數據:

select create_date, max(num) from blog_test group by create_date;

Django 語句:

TestModel.objects.values("create_date").annotate(max_num=Max("num"))

7、group by 分組統計 sum

按照日期計算 num 的總數:

select create_date, sum(num) from blog_test group by create_date;

Django 語句:

from django.db.models import Sum
TestModel.objects.values("create_date").annotate(sum_num=Sum("num"))

8、group by 分組統計 count + distinct

如果是對需要對 user_id 進行去重處理的統計,SQL 如下:

select create_date, count(distinct user_id) from blog_test group by create_date;

Django 語句:

TestModel.objects.values("create_date").annotate(count=Count("user_id", distinct=True))

以上就是本篇筆記全部內容,接下來會是幾個深入一點的知識點的介紹,比如一個 Model 示例 save() 方法的繼承和修改、主鍵自增和欄位更新的操作。

如果想獲取更多相關文章,可掃碼關註閱讀:
image


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 還在為npm i安裝大量依賴等待時間較長,npm扁平化node_modules依賴版本衝突在苦惱嗎,不用苦惱pnpm為你保駕護航 ...
  • Element Plus是一個用於Vue.js的UI組件庫,為開發人員提供了一組可重用和可定製化的組件,用於構建現代Web應用程式。它是流行的Element UI庫的擴展,重點是提高性能和可訪問性。 Element Plus包括廣泛的組件,如按鈕、表單、表格、對話框等。 除了常規的UI組件外,Ele ...
  • JavaScript字元串轉數字的5種方法及其陷阱 摘要 :JavaScript 是一個神奇的語言,字元串轉數字有 5 種方法,各有各的坑法! 原文: Converting Strings to Number in Javascript: Pitfalls 譯者: Fundebug 轉載地址: 本文 ...
  • #1、方法 const formatStr = (str) => { const value = str.replace( /[`:_~!@#$%^&*() \+ =<>?"{}|, \/ ;' \\ [ \] ·~!@#¥%……&*()—— \+ ={}|《》?:“”【】、;‘’,。、-]/g, ...
  • MVVM模式(Model-View-ViewModel):它的目標是將用戶界面(UI)的邏輯與業務邏輯分離。該模式的核心思想是將UI分為視圖(View)和視圖模型(ViewModel),並通過數據綁定實現二者之間的通信。 在MVVM模式中,視圖(View)表示用戶界面的呈現部分,視圖模型(ViewM ...
  • 本博文記錄CSS中比較常用的背景屬性,包括背景顏色:background-color、背景圖片:background-image、背景平鋪:background-repeat、背景位置:background-position和背景附著:background-attachment。同時記錄了背景色半透... ...
  • 本文分享自天翼雲開發者社區@《基於SpringBoot實現單元測試的多種情境/方法(二)》, 作者:才開始學技術的小白 1 Mock基礎回顧 在上一篇分享中我們詳細介紹了簡單的、用mock來模擬介面測試環境的方法,具體的使用樣例我們再回顧一下: 1.首先是最簡單的不需要傳參的示例,需要註意的是,可能 ...
  • 簡介 外觀模式(Facade Pattern),也叫門面模式,是一種結構型設計模式。它向現有的系統添加一個高層介面,隱藏子系統的複雜性,這個介面使得子系統更加容易使用。 如果你需要一個指向複雜子系統的直接介面,且該介面的功能有限,則可以使用外觀模式。或者需要將子系統組織為多層結構,可以使用外觀。 作 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...