IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> 零基础自学SQL课程 | SQL中的日期函数大全 -> 正文阅读

[大数据]零基础自学SQL课程 | SQL中的日期函数大全

大家好,我是宁一。

今天是我们的第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 函数。

点击关注,更新课程第一时间通知哦~

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-06-29 19:08:56  更:2022-06-29 19:11:51 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年4日历 -2024/4/23 21:11:18-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码