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


    大家好,我是宁一。

    今天是我们的第21课:SQL中的日期函数。

    MySQL中内置的日期函数,包括获取日期、日期格式化、日期计算,我们分别来看看。

    1、获取日期函数

    MySQL内置的获取日期时间函数:

    1. SELECT
    2. NOW() AS '当前日期+时间',
    3. CURDATE() AS '当前日期',
    4. CURTIME() AS '当前时间';

    获取具体年月日函数:

    1. SELECT
    2. YEAR("2022-04-11 15:44:28") AS '年',
    3. MONTH("2022-04-11 15:44:28") AS '月',
    4. DAY("2022-04-11 15:44:28") AS '日',
    5. HOUR("2022-04-11 15:44:28") AS '小时',
    6. MINUTE("2022-04-11 15:44:28") AS '分钟',
    7. SECOND("2022-04-11 15:44:28") AS '秒',
    8. DAYNAME("2022-04-11 15:44:28") AS '星期几',
    9. MONTHNAME("2022-04-11 15:44:28") AS '几月';

    实例:在Students表中,找出生日Sage为1995年的学生记录。

    1. SELECT *
    2. FROM Students
    3. WHERE YEAR(Sage) = 1995

    我们之前也做过这个题,用BETWEEN…AND…实现的,可以点击主页找到第五讲--WHERE条件子句复习一下~

    2、格式化日期函数

    我们主要使用 DATE_FORMAT、TIME_FORMAT函数对日期和时间进行格式化,来看看具体用法。

    1. SELECT
    2. NOW() AS "现在时间",
    3. DATE_FORMAT(NOW(), '%Y.%m.%d') AS '格式化日期',
    4. TIME_FORMAT(NOW(), '%h:%i:%s') AS '格式化时间'

    可以使用的格式有:

    3、计算日期函数

    实际业务中,我们经常要计算日期和时间,比如在日期基础上增加减少一天,或者计算日期间隔,来看看具体用法。

    在日期基础上增加减少天数:

    1. SELECT
    2. NOW() AS "现在时间",
    3. DATE_ADD(NOW(), INTERVAL 1 DAY) AS "增加1天",
    4. DATE_SUB(NOW(), INTERVAL 1 DAY) AS "减少1天"

    还可以增加减少年、月、小时、分钟:

    1. SELECT
    2. NOW() AS "现在时间",
    3. DATE_ADD(NOW(), INTERVAL 1 YEAR) AS "增加1年",
    4. DATE_SUB(NOW(), INTERVAL 1 MONTH) AS "减少1天",
    5. DATE_SUB(NOW(), INTERVAL 1 HOUR) AS "减少1小时"

    计算两个日期间隔天数:

    1. SELECT
    2. DATEDIFF('2022-04-11','2021-04-11') AS "间隔天数",
    3. 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数值函数,取小于年龄的大整数。

    1. SELECT
    2. DATE_FORMAT(NOW(),'%Y-%m-%d') AS '今天日期',
    3. Sname AS '学生姓名',
    4. FLOOR(DATEDIFF(NOW(),Sage)/365) AS "学生年龄"
    5. FROM Students;

    要注意上面这些函数不是标准SQL语句,而是MySQL软件中内置的函数,在Oracle、或者SQL Server中不一定通用。

    下节课我们讲讲 IF 函数。

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

  • 相关阅读:
    GreaalVM编译springboot编译springboot
    【python基础】python的继承与多态,子类中调用父类方法和属性
    Spring安装和使用(Eclipse环境)
    CentOS7 安装MySQL 图文详细教程
    JavaScript参考手册 Array函数(更新完成)字数:22787字(搞定!)
    矢量三维电磁铁的技术参数
    Faster RCNN基本结构和各部分原理详解
    剑指offer--重建二叉树
    Web大学生网页作业成品 基于HTML+CSS+JavaScript个人简历介绍 学生个人网站作业设计代做 学生个人网页设计作品
    docker打包发版
  • 原文地址:https://blog.csdn.net/shine_a/article/details/125460200