1. 介绍

日期函数主要介绍两个大类,Extract() 和 Trunc()

Extract() 函数作用是提取日期,比如我们可以提取一个日期字段的年份,月份,日等数据

Trunc() 的作用则是截取,比如 2022-06-18 12:12:12,我们可以根据需求获取到日期 2020-06-18,或者更细粒度到时分秒

models.py

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)

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 Extractexperiment = 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 modelsexperiment = 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() 他们的结果如下:

需要注意的是,截取到年、月、季度的数据,因为不关心当前时间刻度之下的数据,所以日期的日,都会被置为1,时间都会是0

从输出的结果看,日期时间都精确到了我们设置的细度,那么我们就可以利用这个来进行年度、月度、季度、以及日度等一些数据的统计

>>> 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

接下来以日度数据为例,我们做一下统计,统计每一天的数据的数量:

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() 这种,这里就不展开介绍了。

数据库函数之日期函数相关推荐

  1. oracle数据库函数手册,oracle函数大全连载(四)T

    TAN 返回数字的正切值SQL> select tan(20),tan(10) from dual; TAN(20)   TAN(10)--------- ---------2.2371609 ...

  2. python调用数据库数据创建函数_Pyhton应用程序数据库函数封装

    1.函数 2.迭代器 3.递归 4.数据库函数 5.fetchall函数 1.函数:实现指定功能代码的集合 def 函数名( ) : 2.在python中没有括号,函数体以缩进的方式进行展示 快捷键: ...

  3. Oracle数据库之日期函数

    今天给大家介绍一下oracle数据中的日期函数的用法.废话不多说,我们看一下oracle给我们提供了那些函数? 1.sysdate 用途:获取当前系统时间. 2.to_date('字符类型','日期类 ...

  4. Mysql数据库函数(数字,字符串,日期时间)

    文章目录 Mysql数据库函数(数字,字符串,日期时间) 数学函数 字符串函数 日期函数 Mysql数据库函数(数字,字符串,日期时间) 数学函数 abs(x) :返回x的绝对值 rand() :返回 ...

  5. MySQL数据库中arg函数_数据库函数有哪些

    数据库函数有:1.数学函数[abs(x).bin(x)]:2.聚合函数[avg(col)]:3.字符串函数[ascii(char)]:4.日期和时间函数[curdate()]:5.加密函数[decod ...

  6. pandas使用date_range函数按照指定的频率(freq)和指定的个数(periods)生成dataframe的时间格式数据列、基于dataframe的日期数据列生成日期索引

    pandas使用date_range函数按照指定的频率(freq)和指定的个数(periods)生成dataframe的时间格式数据列.基于dataframe的日期数据列生成日期索引(dates in ...

  7. thinkphp mysql函数_php封装的数据库函数与用法示例【参考thinkPHP】

    本文实例讲述了php封装的数据库函数与用法.分享给大家供大家参考,具体如下: 从Thinkphp里面抽离出来的数据库模块,感觉挺好用 common.php: /** * 通用函数 */ //包含配置文 ...

  8. 5.单行函数,多行函数,字符函数,数字函数,日期函数,数据类型转换,数字和字符串转换,通用函数(case和decode)

     1  多行函数(理解:有多个输入,但只输出1个结果) SQL>select count(*) from emp; COUNT(*) ------------- 14 B 字符函数Lower ...

  9. php访问mysql函数吗,PHP访问MySQL数据库函数简介

    PHP访问MySQL数据库函数简介 PHP访问MySQL数据库函数简介 1. 进行数据库连接 连接数据库服务器,就是客户端向己运行的数据库服务器发出连接请求, 成功以后就可以对数据库进行相应操作,由于 ...

最新文章

  1. LPMS_IMU在TX2上使用
  2. centos 6.5下编译安装、配置高性能服务器Nginx
  3. 缓存-SpringCache-整合体验@Cacheable
  4. (30)FPGA原语设计(单端时钟转差分时钟)
  5. mysql did not start_mysql 服务无法启动
  6. Windows下配置Apache服务器
  7. 解决libxml2不支持中文的问题
  8. 气动人工肌肉的应用概况
  9. 向NS2中添加协议PING[转载]
  10. 一文读懂IT行业都有哪些职位
  11. springMVC源码分析--HandlerMethod
  12. XBee/XBee-Pro ® ZigBee 模块
  13. 北航2020级算法上机 C1-I 对抗 题解
  14. 电影先生搭建影视网站教程
  15. VNC Viewer 远程 Unable to connect to VNC Server using your chosen securitysetting. 问题解决
  16. 只能输入0-9的数字和小数点和-号
  17. 【JDY-23蓝牙模块调试】
  18. Struts2漏洞分析与复现合集
  19. ASP.net的ItemDataBound事件与LinqToSql数据源关于e.Item.DataItem的类型
  20. oracle 中文乱码 java_oracle ---中文乱码问题

热门文章

  1. 邮件接收中Postfix、Dovecot、Squirrelmail、MySQL、AMaVis、Clam AntiVirus和SpamAssasin的功能解析
  2. 土圭垚㙓数学课(四)空间变换
  3. leo谈谈写简历之基础篇
  4. 新生儿黄疸警惕蚕豆病
  5. python自动化和教程_python自动化基本技术原理
  6. 【一文弄懂】优先经验回放(PER)论文-算法-代码
  7. Linux内核优化(二):网络线程优化
  8. 模糊数学学习笔记 6:模糊综合评判
  9. Tomcat的默认管理员密码是什么?
  10. [SWPU2019]Web1 1