mysql实用系列:日期格式化

在MySQL中,你可以使用DATE_FORMAT()函数来格式化日期。DATE_FORMAT() 函数通常用于格式化 DATETIME 或 TIMESTAMP类型的字段。这个函数允许你按照指定的格式来显示日期和时间。下面是一些常见的日期格式化的例子:

  1. 显示年-月-日:

    sql 复制代码
    SELECT DATE_FORMAT(NOW(), '%Y-%m-%d');
  2. 显示月/日/年:

    sql 复制代码
    SELECT DATE_FORMAT(NOW(), '%m/%d/%Y');
  3. 显示完整的日期和时间:

    sql 复制代码
    SELECT DATE_FORMAT(NOW(), '%Y-%m-%d %H:%i:%s');
  4. 显示小时和分钟:

    sql 复制代码
    SELECT DATE_FORMAT(NOW(), '%H:%i');
  5. 显示星期几:

    sql 复制代码
    SELECT DATE_FORMAT(NOW(), '%W'); -- 星期几(Sunday=0, ..., Saturday=6)
  6. 显示月份的名称:

    sql 复制代码
    SELECT DATE_FORMAT(NOW(), '%M'); -- 月份的名称(January, ..., December)
  7. 显示月份的缩写:

    sql 复制代码
    SELECT DATE_FORMAT(NOW(), '%b'); -- 月份的缩写(Jan, ..., Dec)
  8. 显示年份的最后两位数字:

    sql 复制代码
    SELECT DATE_FORMAT(NOW(), '%y');
  9. 显示AM或PM:

    sql 复制代码
    SELECT DATE_FORMAT(NOW(), '%p');
  10. 显示秒:

    sql 复制代码
    SELECT DATE_FORMAT(NOW(), '%s');

这些是DATE_FORMAT()函数的一些基本用法。你可以根据需要组合不同的格式化选项来创建自定义的日期格式。

如果你尝试对一个非日期时间类型的字段使用 DATE_FORMAT(),比如 INT 或 VARCHAR,MySQL 会返回一个错误,因为它无法将这些类型的数据解释为日期或时间。

如果你有一个非日期时间类型的字段,但你知道它包含的是日期或时间信息,你可能需要先将其转换为 DATETIME 类型,然后再使用 DATE_FORMAT() 函数。例如,如果一个 VARCHAR 字段包含日期时间字符串,你可以使用 STR_TO_DATE() 函数将其转换:

sql 复制代码
SELECT DATE_FORMAT(STR_TO_DATE(your_varchar_column, '%Y-%m-%d %H:%i:%s'), '%Y-%m-%d %H:%i:%s');

这里,STR_TO_DATE() 函数将字符串转换为 DATETIME 类型,然后 DATE_FORMAT() 函数将其格式化为所需的格式。

相关推荐
韩立学长2 小时前
【开题答辩实录分享】以《自助游网站的设计与实现》为例进行选题答辩实录分享
java·mysql·spring
SAP小崔说事儿2 小时前
在数据库中将字符串拆分成表单(SQL和HANA版本)
java·数据库·sql·sap·hana·字符串拆分·无锡sap
川贝枇杷膏cbppg3 小时前
asmcmd
数据库·oracle
JIngJaneIL4 小时前
基于java+ vue助农电商系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
q_19132846954 小时前
基于Springboot+MySQL+RuoYi的会议室预约管理系统
java·vue.js·spring boot·后端·mysql·若依·计算机毕业设计
IndulgeCui4 小时前
基于CentOS7 DM8单机部署配置记录-20251216
数据库
surtr14 小时前
关系代数与关系型数据库
数据库·sql·数据库系统
学海_无涯_苦作舟4 小时前
MySQL面试题
数据库·mysql·面试
老邓计算机毕设4 小时前
SSM校内二手书籍交易系统的设计与实现an1k0(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·ssm 框架开发·ssm 校内二手书籍交易系统
天行健,君子而铎5 小时前
高性能、可控、多架构:教育行业数据库风险监测一体化解决方案
数据库·架构