【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的时间函数,在我们写查询的时候会比较方便使用,可以现拿现取!

相关推荐
一只小bit1 小时前
MySQL 索引:从聚簇到普通索引,如何加快查询效率?
数据库·mysql·oracle
洛克大航海4 小时前
解锁 PySpark SQL 的强大功能:有关 App Store 数据的端到端教程
linux·数据库·sql·pyspark sql
XueminXu5 小时前
ClickHouse数据库的表引擎
数据库·clickhouse·log·表引擎·mergetree·special·integrations
冒泡的肥皂5 小时前
MVCC初学demo(二
数据库·后端·mysql
代码程序猿RIP5 小时前
【Redis 】Redis 详解以及安装教程
数据库·etcd
小生凡一6 小时前
redis 大key、热key优化技巧|空间存储优化|调优技巧(一)
数据库·redis·缓存
oe10196 小时前
好文与笔记分享 A Survey of Context Engineering for Large Language Models(上)
数据库·笔记·语言模型·agent·上下文工程
小马哥编程6 小时前
【软考架构】案例分析-对比MySQL查询缓存与Memcached
java·数据库·mysql·缓存·架构·memcached
一 乐6 小时前
高校后勤报修系统|物业管理|基于SprinBoot+vue的高校后勤报修系统(源码+数据库+文档)
java·前端·javascript·数据库·vue.js·毕设
折翼的恶魔6 小时前
SQL190 0级用户高难度试卷的平均用时和平均得分
java·数据库