当前位置:网站首页>零基础自学SQL课程 | SQL中的日期函数大全
零基础自学SQL课程 | SQL中的日期函数大全
2022-06-27 21:13:00 【喵宁一】
大家好,我是宁一。
今天是我们的第21课:SQL中的日期函数。
MySQL中内置的日期函数,包括获取日期、日期格式化、日期计算,我们分别来看看。
1、获取日期函数
MySQL内置的获取日期时间函数:
SELECT
NOW() AS '当前日期+时间',
CURDATE() AS '当前日期',
CURTIME() AS '当前时间';
获取具体年月日函数:
SELECT
YEAR("2022-04-11 15:44:28") AS '年',
MONTH("2022-04-11 15:44:28") AS '月',
DAY("2022-04-11 15:44:28") AS '日',
HOUR("2022-04-11 15:44:28") AS '小时',
MINUTE("2022-04-11 15:44:28") AS '分钟',
SECOND("2022-04-11 15:44:28") AS '秒',
DAYNAME("2022-04-11 15:44:28") AS '星期几',
MONTHNAME("2022-04-11 15:44:28") AS '几月';
实例:在Students表中,找出生日Sage为1995年的学生记录。
SELECT *
FROM Students
WHERE YEAR(Sage) = 1995
我们之前也做过这个题,用BETWEEN…AND…实现的,可以点击主页找到第五讲--WHERE条件子句复习一下~
2、格式化日期函数
我们主要使用 DATE_FORMAT、TIME_FORMAT函数对日期和时间进行格式化,来看看具体用法。
SELECT
NOW() AS "现在时间",
DATE_FORMAT(NOW(), '%Y.%m.%d') AS '格式化日期',
TIME_FORMAT(NOW(), '%h:%i:%s') AS '格式化时间'
可以使用的格式有:
3、计算日期函数
实际业务中,我们经常要计算日期和时间,比如在日期基础上增加减少一天,或者计算日期间隔,来看看具体用法。
在日期基础上增加减少天数:
SELECT
NOW() AS "现在时间",
DATE_ADD(NOW(), INTERVAL 1 DAY) AS "增加1天",
DATE_SUB(NOW(), INTERVAL 1 DAY) AS "减少1天"
还可以增加减少年、月、小时、分钟:
SELECT
NOW() AS "现在时间",
DATE_ADD(NOW(), INTERVAL 1 YEAR) AS "增加1年",
DATE_SUB(NOW(), INTERVAL 1 MONTH) AS "减少1天",
DATE_SUB(NOW(), INTERVAL 1 HOUR) AS "减少1小时"
计算两个日期间隔天数:
SELECT
DATEDIFF('2022-04-11','2021-04-11') AS "间隔天数",
DATEDIFF('2022-04-11 01:00','2022-04-10 23:00') AS "间隔天数"
注意DATEDIFF函数会忽略时间部分,只算日期差异,比如,上面SQL语句中04-10 23:00到04-11 01:00只差了两个小时,但是用DATEDIFF函数会计算时间间隔为1天。
作业:在Students表中,通过学生生日Sage,计算每个学生的年龄,最终显示今天日期、学生姓名、学生年龄3列。
作业解析:通过DATEDIFF函数,计算今天与学生生日Sage相差的天数,除以365得到年数,再通过FLOOR数值函数,取小于年龄的大整数。
SELECT
DATE_FORMAT(NOW(),'%Y-%m-%d') AS '今天日期',
Sname AS '学生姓名',
FLOOR(DATEDIFF(NOW(),Sage)/365) AS "学生年龄"
FROM Students;
要注意上面这些函数不是标准SQL语句,而是MySQL软件中内置的函数,在Oracle、或者SQL Server中不一定通用。
下节课我们讲讲 IF 函数。
点击关注,更新课程第一时间通知哦~
边栏推荐
猜你喜欢
居家办公竟比去公司上班还累?
Small chip chiplet Technology
[tinyriscv verilator] branch transplanted to Da Vinci development board of punctual atom
【PCL自学:PCLPlotter】PCLPlotter绘制数据分析图
发射,接收天线方向图
Introduction to quantitative trading
How to set the enterprise wechat group robots to send messages regularly?
Discuz小鱼游戏风影传说商业GBK+UTF8版模板/DZ游戏网站模板
【数字IC/FPGA】检测最后一个匹配序列的位置
【PCL自学:Segmentation4】基于Min-Cut点云分割
随机推荐
How to set the enterprise wechat group robots to send messages regularly?
Small chip chiplet Technology
[tinyriscv verilator] branch transplanted to Da Vinci development board of punctual atom
系统学习+主动探索,是最舒适的入门学习方式!
Swing UI——容器(一)
Technical implementation process of easycvr platform routing log function [code attached]
go日志包 log的使用
[try to hack] kill evaluation
用pytorch进行CIFAR-10数据集分类
To build a "strong core" in Nansha, the first IC Nansha conference was held in Nansha
思源笔记订阅停止直接删云端数据嘛?
良/恶性乳腺肿瘤预测(逻辑回归分类器)
Introduction to quantitative trading
刚开始看英文文献,想问一下各位,最初应该怎么看进去?
Stream + Nacos
const关键字及其作用(用法),C语言const详解
图的存储结构
MySQL删除表后如何使ID从1开始
Halcon's region: features of multiple regions (6)
Usage of vivado vio IP