Django筆記二十五之資料庫函數之日期函數

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

本文首發於公眾號:Hunter後端 原文鏈接:Django筆記二十五之資料庫函數之日期函數 日期函數主要介紹兩個大類,Extract() 和 Trunc() Extract() 函數作用是提取日期,比如我們可以提取一個日期欄位的年份,月份,日等數據 Trunc() 的作用則是截取,比如 2022-0 ...


本文首發於公眾號:Hunter後端
原文鏈接:Django筆記二十五之資料庫函數之日期函數

日期函數主要介紹兩個大類,Extract() 和 Trunc()

Extract() 函數作用是提取日期,比如我們可以提取一個日期欄位的年份,月份,日等數據

Trunc() 的作用則是截取,比如 2022-06-18 12:12:12,我們可以根據需求獲取到日期 2020-06-18,或者更細粒度到時分秒

這次我們用到下麵這個 model:

class Experiment(models.Model):
    start_datetime = models.DateTimeField()
    start_date = models.DateField(null=True, blank=True)
    start_time = models.TimeField(null=True, blank=True)
    end_datetime = models.DateTimeField(null=True, blank=True)
    end_date = models.DateField(null=True, blank=True)
    end_time = models.TimeField(null=True, blank=True)

我們還是將其放到 blog/models.py 下,相關的 migration 操作這裡不多做介紹

  1. Extract()
  2. Trunc()

1、Extract()

這個函數接受日期時間欄位名稱,和查詢的年、月、日、時、分、秒等作為參數,提取出相應的值以整數類型返回

日期類型欄位包括:DateTimeField,DateField,TimeField
提取的類型列舉如下:

  • year——年份
  • quarter——季度
  • month——月份
  • day——某日
  • week——周數,一年的第幾周
  • weekday——周幾,周日的值是1,周一是2,一直到周六是7
  • hour——小時
  • minute——分鐘
  • second——秒數

首先創建測試用的數據:

from datetime import datetime
start = datetime(2015, 6, 15, 12, 30, 56)
end = datetime(2015, 7, 2, 17, 21, 43)

from blog.models import Experiment
Experiment.objects.create(
    start_datetime=start, start_date=start.date(),
    end_datetime=end, end_date=end.date())

新增欄位獲取開始時間的年份,周數,周幾以及該天的小時數

from blog.models import Experiment
from django.db.models.functions import Extract

experiment = Experiment.objects.annotate(
    start_year=Extract('start_datetime', 'year'),
    start_week=Extract('start_datetime', 'week'),
    start_week_day=Extract('start_datetime', 'week_day'),
	start_hour=Extract('start_datetime', 'hour')
).get(id=1)

print(experiment.start_year)
print(experiment.start_week)
print(experiment.start_week_day)
print(exprtiment.start_hour)

搜索特定年份數據

Extract() 函數的用法也可以用於搜索特定的日期的某一項,比如某年,某月等

Experiment.objects.filter(start_datetime__year=Extract('end_datetime', 'year'))

具體到日期某一項的用法

前面介紹了 Extract() 函數的用法是,接收欄位名和日期項,Django 同時提供了另一種簡便的、比Extract()函數更具體的用法。

比如我們需要需要搜索年,可以直接使用函數為 ExtractYear()

搜索月,使用函數 ExtractMonth()等等。

每一種在我們上面可接收的參數都有其對應的函數,傳參為需要處理的欄位,以下是使用示例:

from blog.models import Experiment
from django.db.models.functions import ExtractYear, ExtractWeek
expriment = Experiment.objects.annotate(
    start_year=ExtractYear('start_datetime'),
    start_week=ExtractWeek('start_datetime')
).get(id=1)

print(expriment.start_year)
print(expriment.start_week)

如果是周數、時、分、秒的操作,函數名將上面的年月日的英文替換即可

2、Trunc()

這是一個對日期和時間截取的函數,我們可以將時間精確到 年、季度、月、日、時、分、秒

接受三個參數:

  • expression: 欄位,可以是 DateField, DateTimeField, TimeField 等
  • kind: 精確到的程度,可以是 year,day,quarter等
  • output_field: 輸出格式,可以根據 kind 的值設置到最小值,如果不傳這個參數,則預設是expression 的值

假設一個日期時間為 2022–05-16 12:34:56

我們可以挨個處理一下:

# 創建數據
from datetime import datetime
start_datetime = datetime(year=2022, month=5, day=16, hour=12, minute=34, second=56)

Experiment.objects.create(start_datetime=start_datetime)

from django.db.models.functions import Trunc
from django.db import models

experiment = Experiment.objects.annotate(
    start_year=Trunc('start_datetime', 'year', output_field=models.DateField()),
    start_quarter=Trunc('start_datetime', 'quarter', output_field=models.DateField()),
    start_month=Trunc('start_datetime', 'month', output_field=models.DateField()),
    start_day=Trunc('start_datetime', 'day', output_field=models.DateField()),
    start_hour=Trunc('start_datetime', 'hour', output_field=models.DateTimeField()),
    start_minute=Trunc('start_datetime', 'minute', output_field=models.DateTimeField()),
    start_second=Trunc('start_datetime', 'second', output_field=models.DateTimeField()),
).get(id=2)

然後挨個 print() 他們的結果如下:

>>> print(experiment.start_year)
2022-01-01
>>> print(experiment.start_quarter)
2022-04-01
>>> print(experiment.start_month)
2022-05-01
>>> print(experiment.start_day)
2022-05-16
>>> print(experiment.start_hour)
2022-05-16 12:00:00+00:00
>>> print(experiment.start_minute)
2022-05-16 12:34:00+00:00
>>> print(experiment.start_second)
2022-05-16 12:34:56+00:00

需要註意的是,截取到年、月、季度的數據,因為不關心當前時間刻度之下的數據,所以日期的日,都會被置為1,時間都會是0

從輸出的結果看,日期時間都精確到了我們設置的細度,那麼我們就可以利用這個來進行年度、月度、季度、以及日度等一些數據的統計

接下來以日度數據為例,我們做一下統計,統計每一天的數據的數量:

from django.db.models import Count
Experiment.objects.annotate(start_day=Trunc("start_datetime", "day", output_field=models.DateField())).values("start_day").annotate(count_day=Count("id"))

與 Extract() 函數類似,Trunc() 函數也有一些可以直接操作到時間的函數,比如 TruncYear(), TruncMonth() 這種,這裡就不展開介紹了。

以上就是本篇筆記全部內容,下一篇將介紹資料庫函數里計算公式相關函數。

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

image


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

-Advertisement-
Play Games
更多相關文章
  • 一、http是什麼 通俗來講,http就是電腦通過網路進行通信的規則,是一個基於請求與響應,無狀態的,應用層協議。常用於TCP/IP協議傳輸數據。目前任何終端之間任何一種通信方式都必須按Http協議進行,否則無法連接。tcp(三次握手,四次揮手)。 請求與響應:客戶端請求、服務端響應數據。 無狀態 ...
  • * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關係, * 將對象之間的通信封裝到一個中介者對象中,從而使得各個對象之間的關係更加鬆散。 * 在中介者模式中,對象之間不再直接相互交互,而是通過中介者來中轉消息。 ...
  • 他們集團的信息化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,項目投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多餘。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ...
  • 設計是一個讓人夢想成真過程,開始編碼、測試、調試之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ...
  • 作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基於此我們探索了一種新的技術體系及交付方案來解決如上問題。 ...
  • 值傳遞不會改變本身,引用傳遞(如果傳遞的值需要實例化到堆里)如果發生修改了會改變本身。 1.基本數據類型都是值傳遞 package com.example.basic; public class Test { public static void main(String[] args) { int ...
  • 第一個 Scala 程式 shell裡面輸入 $ scala scala> 1 + 1 res0: Int = 2 scala> println("Hello World!") Hello World! 文件形式 object HelloWorld { /* 這是我的第一個 Scala 程式 * 以 ...
  • 理解 函數指針 指向函數的指針。比如: 理解函數指針的偽代碼 void (*p)(int type, char *data); // 定義一個函數指針p void func(int type, char *data); // 聲明一個函數func p = func; // 將指針p指向函數func ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...