【SQL】写SQL查询时,常用到的日期函数

我们在做SQL的查询,日期函数是我们经常会用得到的函数,可以方便调用用于处理日期和时间数据。

以下是一些常见的日期函数及其用法示例:

1. 直接报出日期和时间

  • CURRENT_DATE:返回当前日期。
  • NOW():返回当前日期和时间。

示例

sql 复制代码
SELECT CURRENT_DATE; -- 2024-07-09
SELECT NOW(); -- 2024-07-09 10:00:00

2. 将完整的日期和时间,拆分成具体的部分

  • YEAR(date):从日期中提取年份。
  • MONTH(date):从日期中提取月份。
  • DAY(date):从日期中提取日。
  • HOUR(time):从时间中提取小时。
  • MINUTE(time):从时间中提取分钟。

示例

sql 复制代码
SELECT YEAR('2024-07-09'); -- 2024
SELECT MONTH('2024-07-09'); -- 7
SELECT DAY('2024-07-09'); -- 9
SELECT HOUR('10:30:00'); -- 10
SELECT MINUTE('10:30:00'); -- 30

3. 计算日期和时间的间隔

  • DATE_ADD(date, INTERVAL value unit):给日期添加一个时间间隔。
  • DATE_SUB(date, INTERVAL value unit):从日期减去一个时间间隔。

示例

sql 复制代码
SELECT DATE_ADD('2024-07-09', INTERVAL 1 DAY); -- 2024-07-10
SELECT DATE_SUB('2024-07-09', INTERVAL 1 MONTH); -- 2024-06-09

4. 格式化日期和时间

  • DATE_FORMAT(date, format):按照指定格式返回日期。

示例

sql 复制代码
SELECT DATE_FORMAT('2024-07-09 10:30:00', '%Y-%m-%d %H:%i:%s'); -- 2024-07-09 10:30:00

5. 计算两个日期之间的日期差

  • DATEDIFF(date1, date2):计算两个日期之间的天数差。

示例

sql 复制代码
SELECT DATEDIFF('2024-07-10', '2024-07-09'); -- 1

6. 转换日期格式

  • STR_TO_DATE(string, format):将符合特定格式的字符串转换为日期格式。

示例

sql 复制代码
SELECT STR_TO_DATE('2024-7-9', '%Y-%m-%d'); -- 2024-07-09

7. 星期和季度

  • WEEKDAY(date):返回给定日期是星期几(0 = 星期一,1 = 星期二,...,6 = 星期日)。
  • QUARTER(date):返回日期所在的季度。

示例

sql 复制代码
SELECT WEEKDAY('2024-07-09'); -- 返回星期几的数字
SELECT QUARTER('2024-07-09'); -- 3

SQL的时间函数,在我们写查询的时候会比较方便使用,可以现拿现取!

相关推荐
史蒂芬_丁38 分钟前
Qt, C++数据类型扩展问题
数据库·c++·qt
lpfasd1231 小时前
MariaDB Docker容器权限配置问题分析与解决方案
数据库·docker·mariadb
Yvonne爱编码2 小时前
数据库---Day2 数据库操作
数据库
BduL OWED3 小时前
Redis之Redis事务
java·数据库·redis
星星也在雾里3 小时前
Dify Agent + FastAPI + PostgreSQL实现数据库查询
数据库·人工智能·fastapi
TDengine (老段)3 小时前
以事件为核心 + 以资产为核心:工业数据中缺失的关键一环
大数据·数据库·人工智能·时序数据库·tdengine·涛思数据
r_oo_ki_e_3 小时前
快速复习mysql
数据库·mysql
huabiangaozhi4 小时前
修改表字段属性,SQL总结
java·数据库·sql
IvorySQL4 小时前
第 6 次执行后,PostgreSQL 执行计划为何突变?
数据库·postgresql·开源