0


MySQL|MySQL 中 `DATE_FORMAT()` 函数的使用

文章目录

概述
DATE_FORMAT()

是 MySQL 中的一个内置函数,用于格式化日期和时间数据。它可以根据指定的格式字符串来展示日期和时间,使得数据更容易阅读和理解。本文档将详细介绍

DATE_FORMAT()

函数的使用方法及其常见应用场景。

方法签名
DATE_FORMAT(date, format)
  • 参数: - date: 日期或时间的表达式,可以是一个日期时间字段或常量。- format: 格式化字符串,用于定义日期和时间的具体格式。
格式化字符
DATE_FORMAT()

支持多种格式化字符,这些字符定义了日期和时间的不同部分。以下是一些常用的格式化字符:
格式化字符描述

%Y

年份,4位数字(例如:2024)

%y

年份,2位数字(例如:24)

%m

月份,2位数字(例如:09)

%b

月份的缩写(例如:Sep)

%M

月份的全称(例如:September)

%d

日,2位数字(例如:18)

%H

小时(24小时制),2位数字(例如:16)

%h

%I

小时(12小时制),2位数字(例如:04)

%i

分钟,2位数字(例如:26)

%s

秒,2位数字(例如:42)

%p

AM 或 PM(仅限于12小时制)

%W

星期几的全称(例如:Wednesday)

%w

星期几,数字表示(例如:3 表示星期三)

%j

一年中的第几天(1 到 366)

%U

一年中的第几周(00 到 53)

%u

一年中的第几周(01 到 53)

基本用法

假设有一个名为

orders

的表,其中有一个

created_at

的字段,存储了订单创建的时间戳。下面是如何使用

DATE_FORMAT()

函数来格式化这个时间戳的例子:

SELECT 
    created_at,
    DATE_FORMAT(created_at,'%Y-%m-%d %H:%i:%s')AS formatted_date
FROM orders;

上述查询将返回

created_at

列,并将每个日期时间值格式化为 “YYYY-MM-DD HH:MM:SS” 格式。

实际应用案例
示例1:显示日期和星期几

假设你需要查询订单创建日期及其对应的星期几:

SELECT 
    created_at,
    DATE_FORMAT(created_at,'%Y-%m-%d %W')AS formatted_date_and_weekday
FROM orders;
示例2:仅显示日期

如果只需要日期部分,可以使用以下格式:

SELECT 
    DATE_FORMAT(created_at,'%Y-%m-%d')AS date_only
FROM orders;
示例3:按周统计订单数量

可以使用

DATE_FORMAT()

函数来获取订单创建的周数,并进行统计:

SELECT 
    DATE_FORMAT(created_at,'%x-%v')AS week,COUNT(*)AS order_count
FROM orders
GROUPBY week;

这里

%x

表示年份的最后两位,

%v

表示一年中的第几周。

注意事项
  • 在使用 DATE_FORMAT() 时,请确保提供的日期时间是有效的。如果日期时间无效,可能会导致错误或不符合预期的结果。
  • DATE_FORMAT() 的格式化字符串区分大小写,不同的格式化字符具有不同的含义。
  • 在设计数据库查询时,考虑到性能因素,如果频繁使用 DATE_FORMAT(),建议考虑使用索引或其他优化手段。
结论
DATE_FORMAT()

函数是 MySQL 中一个非常实用的功能,可以帮助开发者以可定制的方式展示日期和时间数据。通过掌握

DATE_FORMAT()

的使用方法及其格式化字符,可以更灵活地处理和展示时间相关数据。

标签: mysql 数据库

本文转载自: https://blog.csdn.net/weixin_44435110/article/details/142337095
版权归原作者 进击的小白菜 所有, 如有侵权,请联系我们删除。

“MySQL|MySQL 中 `DATE_FORMAT()` 函数的使用”的评论:

还没有评论