MySQL 日期时间格式化函数 DATE_FORMAT() 的使用示例详解

 更新时间:2025年03月03日 11:57:41   作者:Jelian_  
`DATE_FORMAT()`是MySQL中用于格式化日期时间的函数,本文详细介绍了其语法、格式化字符串的含义以及常见日期时间格式组合,感兴趣的朋友一起看看吧

一、DATE_FORMAT()语法

DATE_FORMAT() 是MySQL中用于格式化日期时间的函数:

语法DATE_FORMAT(date, format_string)

  • date:需要格式化的日期化时间值,一般是需要被格式化的日期时间类型(datetime类),但也可以是日期时间形式的字符串
  • format_string:格式化字符串,用于指定日期时间的格式化输出形式

注1:MySQL允许你对具体的日期时间格式的字符串进行格式化,但其他数据库的格式化函数不一定支持,比如Clickhouse的formatDateTime()
注2:MySQL对字符串进行格式化时,日期时间的格式并不固定,你可以用很多特殊字符隔开日期时间,比如: / * - <等,但不能是空格,MySQL会按照YY MM DD HH MM SS的顺序识别字符串中的数字

-- 比如下列SQl语句的执行结果相同,都是 "2024,December,31st"
SELECT DATE_FORMAT( '24-12-31', '%Y,%M,%D') AS format_date
SELECT DATE_FORMAT( '2024-12-31', '%Y,%M,%D') AS format_date
SELECT DATE_FORMAT( '2024/12/31', '%Y,%M,%D') AS format_date
SELECT DATE_FORMAT( '2024*12*31', '%Y,%M,%D') AS format_date
SELECT DATE_FORMAT( '24<<12<<31', '%Y,%M,%D') AS format_date
-- 但如果使用空格间隔,会执行失败,但不会报错,输出结果为NULL
SELECT DATE_FORMAT( '24 12 31', '%Y,%M,%D') AS format_date

二、格式化字符串详解

格式含义
%Y年份:4位数字表示,eg: 2024
%y年份:2位数字表示,eg: 24
%M月份:英文全拼表示,eg: June
%m月份:2位数字表示,范围01-12,eg: 06
%D天数:两位数字表示,范围01-31,eg: 15
%d天数:英文第几天表示,范围 1st-31th,eg: 1st, 2nd, 3rd, 15th
%H小时:两位数字表示,范围00-23,eg: 23
%i分钟:两位数字表示,范围00-59,eg: 59
%S OR %s秒钟:两位数字表示,范围00-59,eg: 16
%W星期:英文全拼表示,eg: Saturday
%w星期:1位数字表示,eg: 6
%T完全时间格式,相当于 %H:%i%s 或 %H:%i:%S,范围00:00:00-23:59:59,eg: 15:30:36

注3:大小写形式%I 和%t无意义

三、常见日期时间格式组合

常见的日期时间格式化形式基本上就是如下几种:
%Y,%M,%D
%Y-%m-%d %H:%i:%s
%Y/%m/%d
%W,%M,%D

SQL语句

SELECT '%Y-%m-%d %H:%i:%s' AS format, DATE_FORMAT( '2024-12-31 23:48:59','%Y-%m-%d %H:%i:%s') AS format_date UNION ALL
SELECT '%Y,%M,%D' AS format, DATE_FORMAT( '2024-12-31 23:48:59','%Y,%M,%D') AS format_date UNION ALL
SELECT '%W,%M,%D' AS format, DATE_FORMAT( '2024-12-31 23:48:59','%W,%M,%D') AS format_date UNION ALL
SELECT '%y/%m/%d' AS format, DATE_FORMAT( '2024-12-31 23:48:59','%y/%m/%d') AS format_date UNION ALL
SELECT '%H:%i:%s' AS format, DATE_FORMAT( '2024-12-31 23:48:59','%H:%i:%s') AS format_date UNION ALL
SELECT '%H:%i:%S' AS format, DATE_FORMAT( '2024-12-31 23:48:59','%H:%i:%S') AS format_date UNION ALL
SELECT '%T' AS format, DATE_FORMAT( '2024-12-31 23:48:59','%T') AS format_date UNION ALL
SELECT '%w,%m-%d' AS format, DATE_FORMAT( '2024-12-31 23:48:59','%w,%m-%d') AS format_date UNION ALL
SELECT '------' AS format, '--------------' AS format_date UNION ALL
SELECT '%H:%I:%s' AS format, DATE_FORMAT( '2024-12-31 23:48:59','%H:%I:%s') AS format_date UNION ALL
SELECT '%t' AS format, DATE_FORMAT( '2024-12-31 23:48:59','%t') AS format_date

执行结果

四、业务场景

在实际的业务应用如报表导出、界面显示、数据分析等,该函数通常用于输出特定格式的日期或时间,当然,DATE_FORMAT()允许你自定义输出格式,只要你定义好格式化字符串即可。

SELECT DATE_FORMAT(startTime,'%Y-%m') AS startTime 
FROM tableA
WHERE column1 = 'option1'

五、总结

DATE_FORMAT()是MySQL中用于格式化输出日期时间的函数,我们可以通过使用该函数满足大多数格式化日期时间的应用场景,本文的示例展示了如何获取当前日期和时间并将其格式化为一个常见的格式,您可以根据需要调整格式字符串来满足您的具体需求。
但需要注意的是,不同的数据库系统可能支持不同的格式字符串,所以在使用时需要参考相应数据库的文档来确定正确的格式字符串。

到此这篇关于MySQL 日期时间格式化函数 DATE_FORMAT() 的使用详解的文章就介绍到这了,更多相关mysql 日期时间格式化内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL 数据查重、去重的实现语句

    MySQL 数据查重、去重的实现语句

    这篇文章主要介绍了MySQL 数据查重、去重的实现语句,帮助大家更好的理解和学习MySQL数据库,感兴趣的朋友可以了解下
    2020-09-09
  • innodb_flush_method取值方法(实例讲解)

    innodb_flush_method取值方法(实例讲解)

    下面小编就为大家带来一篇innodb_flush_method取值方法(实例讲解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-03-03
  • MySQL数据库基础概念和简单使用

    MySQL数据库基础概念和简单使用

    本文介绍了数据库主流数据库类型及MySQL的基本使用,包括:数据库解决文件存储的四大缺陷;MySQL的安装连接、服务器管理及数据库表关系;数据库逻辑存储结构;MySQL架构的跨平台特性;SQL语言分类(DDL、DML、DQL、DCL);存储引擎的作用及对比(InnoDB、MyISAM等)
    2025-08-08
  • mysql 大表批量删除大量数据的实现方法

    mysql 大表批量删除大量数据的实现方法

    这篇文章主要介绍了mysql 大表批量删除大量数据的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-02-02
  • Mysql中的常用调优参数用法及解读

    Mysql中的常用调优参数用法及解读

    文章介绍了MySQL数据库的一些关键配置参数,包括InnoDB缓冲池、redolog缓冲区、日志缓冲区等,并解释了这些参数在数据库性能和事务一致性中的作用,文章通过比喻和实际建议帮助读者理解这些配置参数的合理设置
    2025-12-12
  • MySQL 半同步复制频繁报错的完美解决方案

    MySQL 半同步复制频繁报错的完美解决方案

    在 MySQL 主从复制架构中,半同步复制作为保障数据一致性的重要机制,其稳定性直接影响业务数据的可靠性,本文将结合实际案例,通过智能诊断工具与手动排查相结合的方式,深入解析半同步复制超时问题的成因与解决方案
    2025-06-06
  • MySQL sum后再计算percentage的多种解决办法

    MySQL sum后再计算percentage的多种解决办法

    这篇文章主要介绍了MySQL sum后再计算percentage的多种解决办法,over() 函数,Cross Join,Select 嵌套查询以及 with 函数处理,文中通过代码示例讲解的非常详细,需要的朋友可以参考下
    2024-06-06
  • MySQL中的insert-on-duplicate语句举例详解

    MySQL中的insert-on-duplicate语句举例详解

    这篇文章主要给大家介绍了关于MySQL中insert-on-duplicate语句的相关资料,文中通过图文以及代码示例将insert-on-duplicate的用法介绍的非常详细,对大家的学习或者工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2024-06-06
  • 浅析mysql交互式连接&非交互式连接

    浅析mysql交互式连接&非交互式连接

    下面小编就为大家带来一篇浅析mysql交互式连接&非交互式连接。小编觉挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-03-03
  • MySQL与PHP的基础与应用专题之增删改查

    MySQL与PHP的基础与应用专题之增删改查

    MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,本系列将带你掌握php与mysql的基础应用,本篇从数据库的增删改查开始
    2022-02-02

最新评论