SQL日期函数

简介: SQL日期函数

引言:

在 SQL 中,日期函数具有多种重要作用:

1. 数据筛选和查询

  • 可以根据特定的日期范围来获取所需的数据。例如,通过 BETWEEN 操作符和日期函数,筛选出在某个时间段内的订单记录。
  • 能够提取日期中的特定部分,如年、月、日、小时等,以便按照这些部分进行分类和统计。

2. 数据处理和转换

  • 将日期格式进行转换,以适应不同的显示需求或与其他系统进行数据交互。
  • 计算日期之间的差值,比如计算两个日期之间的天数、月数或年数。

3. 数据验证和约束

  • 在插入或更新数据时,使用日期函数来验证输入的日期是否合法。

4. 数据排序

  • 按照日期字段对数据进行升序或降序排列,以便直观地查看数据的时间顺序。

例如,在 MySQL 中,使用 DATE_FORMAT() 函数可以将日期格式化为特定的字符串格式,如 SELECT DATE_FORMAT('2024-07-15', '%Y-%m-%d') 会返回 2024-07-15 。

又比如,通过 DATEDIFF() 函数计算两个日期之间的天数差,如 SELECT DATEDIFF('2024-07-15', '2024-07-01') 会返回 14 。

总之,SQL 中的日期函数为处理和操作与日期相关的数据提供了强大而灵活的工具,使得数据处理更加准确和高效。

接下来就为大家介绍几种在SQL中常用的日期函数:

一:获取日期时间函数

1.1获取当前时间

SELECT NOW(); # 2024-07-15 21:28:45

1.2获取当前日期

SELECT CURRENT_DATE(); # 2024-07-15

1.3 获取当前时间

SELECT CURRENT_TIME();

二:日期格式化

2.1日期转指定格式字符串

SELECT DATE_FORMAT('2024-07-15 21:31:01', '%Y%m%d%H%i%s');# 20210715213101
说明:
%W 星期名字(Sunday……Saturday) 
%D 有英语前缀的月份的日期(1st, 2nd, 3rd, 等等。)
%Y 年, 数字, 4 位 ★★★
%y 年, 数字, 2 位
%a 缩写的星期名字(Sun……Sat)
%d 月份中的天数, 数字(00……31) ★★★
%e 月份中的天数, 数字(0……31)
%m 月, 数字(01……12) ★★★ month
%c 月, 数字(1……12)
%b 缩写的月份名字(Jan……Dec)
%j 一年中的天数(001……366)
%H 小时(00……23)★★★
%k 小时(0……23)
%h 小时(01……12) 
%I 小时(01……12)
%l 小时(1……12)
%i 分钟, 数字(00……59) ★★★ minite
%r 时间,12 小时(hh:mm:ss [AP]M)
%T 时间,24 小时(hh:mm:ss)
%S 秒(00……59)
%s 秒(00……59) ★★★
%p AM或PM
%w 一个星期中的天数(0=Sunday ……6=Saturday )
%U 星期(0……52), 这里星期天是星期的第一天,查询指定日期属于当前年份的第几个周 ★★★★
%u 星期(0……52), 这里星期一是星期的第一天

实例如下:

# 日期格式化
select date_format(now(),'%Y%m%d%H%i%s');
# 获取当前是星期几
select date_format(now(),'%Y%m%W');
# 查看当前属于一年中的第几个周 以周末作为一个循环
select date_format(now(),'%Y%U');
select date_format('20220108090109','%Y%U');

2.2 字符串转日期

# 日期格式与表达式格式一致即可
SELECT STR_TO_DATE('07/15/2024', '%m/%d/%Y'); # 2024-07-15
SELECT STR_TO_DATE('20240715213508', '%Y%m%d%H%i%s'); # 2024-07-15 21:35:08

三:日期间隔

3.1增加日期间隔

# 间隔单位可以是DAY MONTH MINUTE WEEK YEAR SECOND HOUR
SELECT DATE_ADD(NOW(),INTERVAL 2 DAY); # 2024-07-17 21:38:18
SELECT DATE_ADD(NOW(),INTERVAL 2 MONTH); # 2024-09-15 21:38:44
SELECT DATE_ADD('2022-02-06 22:47:17',INTERVAL 2 MONTH); # 2024-09-15 21:39:40

3.2减去一个时间间隔

SELECT DATE_SUB(NOW(),INTERVAL 3 DAY); # 2024-07-12 21:40:50
SELECT DATE_SUB('2024-07-12 21:40:50',INTERVAL 2 MONTH); # 2024-05-12 21:40:50

3.3日期相差天数

select datediff('2024-07-15','2024-07-12');

3.4相差时间(小时)

select timediff('2024-07-15 21:39:40', '2024-07-18 21:39:40'); -- -72:00:00

四:星期操作

# 返回日期date的星期索引(1=星期天,2=星期一, ……7=星期六)。这些索引值对应于ODBC标准。
SELECT DAYOFWEEK(NOW())-1;
 
# 返回date的星期索引(0=星期一,1=星期二, ……6= 星期天)
SELECT WEEKDAY(NOW())+1

五:其他操作

# 获取日
SELECT DAYOFMONTH(NOW());# 15
# 获取月份
SELECT MONTH(NOW());# 7
# 获取星期几
SELECT DAYNAME(NOW());# Monday
# 获取第几季度
SELECT QUARTER(NOW());# 2024/7/15 --> 3

六:总结

使用 SQL 中的日期函数具有以下显著的好处:

1. 提高数据准确性

  • 确保在处理日期数据时遵循正确的格式和逻辑,减少因手动处理导致的错误。
  • 例如,使用内置的日期验证函数可以防止输入不合法的日期值,如 ISDATE() 函数。

2. 增强查询灵活性

  • 能够根据各种日期条件进行精确的筛选和查询。
  • 比如,要获取本月的销售数据,可以使用日期函数轻松实现。

3. 增强查询灵活性

  • 能够根据各种日期条件进行精确的筛选和查询。
  • 比如,要获取本月的销售数据,可以使用日期函数轻松实现。

4. 优化性能

  • 数据库系统对内置的日期函数进行了优化,执行效率通常较高。
  • 相较于自定义的复杂逻辑,使用日期函数能更有效地利用数据库资源。

5. 统一和标准化

  • 所有使用该数据库的应用都能依赖相同的日期函数进行操作,保证结果的一致性。

6. 适应业务需求变化

  • 当业务规则中对日期的处理要求发生改变时,只需修改使用日期函数的相关部分,而不必更改大量的底层代码。

举例来说,在 SQL Server 中,如果要获取当前日期和时间,可以直接使用 GETDATE() 函数。如果要计算某个订单表中,订单创建日期距离当前日期超过 30 天的记录,可以使用 DATEDIFF(day, OrderCreationDate, GETDATE()) > 30 这样的条件来快速筛选,大大提高了数据处理的效率和准确性。

相关文章
|
28天前
|
SQL Oracle 关系型数据库
SQL优化-使用联合索引和函数索引
在一次例行巡检中,发现一条使用 `to_char` 函数将日期转换为字符串的 SQL 语句 CPU 利用率很高。为了优化该语句,首先分析了 where 条件中各列的选择性,并创建了不同类型的索引,包括普通索引、函数索引和虚拟列索引。通过对比不同索引的执行计划,最终确定了使用复合索引(包含函数表达式)能够显著降低查询成本,提高执行效率。
|
1月前
|
SQL 数据库 数据库管理
数据库SQL函数应用技巧与方法
在数据库管理中,SQL函数是处理和分析数据的强大工具
|
1月前
|
SQL 数据库 索引
SQL中COUNT函数结合条件使用的技巧与方法
在SQL查询中,COUNT函数是一个非常常用的聚合函数,用于计算表中满足特定条件的记录数
|
1月前
|
SQL 开发框架 .NET
sql server日期时间函数
sql server日期时间函数
35 2
|
2月前
|
SQL 关系型数据库 C语言
PostgreSQL SQL扩展 ---- C语言函数(三)
可以用C(或者与C兼容,比如C++)语言编写用户自定义函数(User-defined functions)。这些函数被编译到动态可加载目标文件(也称为共享库)中并被守护进程加载到服务中。“C语言函数”与“内部函数”的区别就在于动态加载这个特性,二者的实际编码约定本质上是相同的(因此,标准的内部函数库为用户自定义C语言函数提供了丰富的示例代码)
|
3月前
|
SQL 数据处理 数据库
|
3月前
|
Java 应用服务中间件 Maven
从零到英雄:一步步构建你的首个 JSF 应用程序,揭开 JavaServer Faces 的神秘面纱
【8月更文挑战第31天】JavaServer Faces (JSF) 是一种强大的 Java EE 标准,用于构建企业级 Web 应用。它提供了丰富的组件库和声明式页面描述语言 Facelets,便于开发者快速开发功能完善且易于维护的 Web 应用。本文将指导你从零开始构建一个简单的 JSF 应用,包括环境搭建、依赖配置、Managed Bean 编写及 Facelets 页面设计。
90 0
|
3月前
|
SQL Oracle 关系型数据库
SQL 中的大小写处理函数详解
【8月更文挑战第31天】
132 0
|
3月前
|
SQL 数据采集 数据挖掘
为什么要使用 SQL 函数?详尽分析
【8月更文挑战第31天】
47 0
|
3月前
|
SQL 存储 关系型数据库
COALESCE 函数:SQL中的空值处理利器
【8月更文挑战第31天】
374 0