百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

MySQL日期格式化简述 mysql 日期格式化 年月日

wptr33 2024-12-23 14:04 19 浏览

MySQL在查询记录时,如果有字段是时间戳,查看结果不方便,不能及时看到时间戳代表的含义,现整理了一套MySQL转换时间的函数,可以方便的看到格式化后的时间。

1. DATE_FORMAT() 函数用于以不同的格式显示日期/时间数据。

1.1 DATE_FORMAT(date,format)

format参数的格式有

%a 缩写星期名

%b 缩写月名

%c 月,数值(0-12)

%D 带有英文前缀的月中的天

%d 月的天,数值(00-31)

%e 月的天,数值(0-31)

%f 微秒

%H 小时 (00-23)

%h 小时 (01-12)

%I 小时 (01-12)

%i 分钟,数值(00-59)

%j 年的天 (001-366)

%k 小时 (0-23)

%l 小时 (1-12)

%M 月名

%m 月,数值(00-12)

%p AM 或 PM

%r 时间,12-小时(hh:mm:ss AM 或 PM)

%S 秒(00-59)

%s 秒(00-59)

%T 时间, 24-小时 (hh:mm:ss)

%U 周 (00-53) 星期日是一周的第一天

%u 周 (00-53) 星期一是一周的第一天

%V 周 (01-53) 星期日是一周的第一天,与 %X 使用

%v 周 (01-53) 星期一是一周的第一天,与 %x 使用

%W 星期名

%w 周的天 (0=星期日, 6=星期六)

%X 年,其中的星期日是周的第一天,4 位,与 %V 使用

%x 年,其中的星期一是周的第一天,4 位,与 %v 使用

%Y 年,4 位

%y 年,2 位

例子:

mysql> select DATE_FORMAT(NOW(),'%b %d %Y %h:%i %p') from dual;

mysql> select DATE_FORMAT(NOW(),'%d %b %y') from dual;

mysql> select DATE_FORMAT(NOW(),'%Y-%c-%d %h:%i:%s') from dual;

mysql> select DATE_FORMAT(NOW(),'%Y-%m-%d %h:%i:%s') from dual;

输出结果:

Sep 04 2022 05:52 PM

04 Sep 22

2022-9-04 05:57:02

2022-09-04 05:58:56


2. MySQL格式化函数 FROM_UNIXTIME()

2.1 FROM_UNIXTIME( unix_timestamp )

  参数:一般为10位的时间戳,如:1417363200

  返回值:有两种,可能是类似 'YYYY-MM-DD HH:MM:SS' 这样的字符串,也有可能是类似于 YYYYMMDDHHMMSS.uuuuuu 这样的数字,具体返回什么取决于该函数被调用的形式。

mysql> select FROM_UNIXTIME(1344887103);

+---------------------------+

| FROM_UNIXTIME(1344887103) |

+---------------------------+

| 2012-08-14 03:45:03 |

+---------------------------+

1 row in set (0.00 sec)


2.2 FROM_UNIXTIME( unix_timestamp ,format )

  参数 unix_timestamp :与方法 FROM_UNIXTIME(unix_timestamp )中的参数含义一样;

  参数 format:转换之后的时间字符串显示的格式;

  返回值:按照指定的时间格式显示的字符串;

mysql> select FROM_UNIXTIME(1344887103,'%Y-%M-%D %h:%i:%s');

+-----------------------------------------------+

| FROM_UNIXTIME(1344887103,'%Y-%M-%D %h:%i:%s') |

+-----------------------------------------------+

| 2012-August-14th 03:45:03 |

+-----------------------------------------------+

1 row in set (0.00 sec)


mysql> select FROM_UNIXTIME(1344887103,'%Y-%m-%D %h:%i:%s');

+-----------------------------------------------+

| FROM_UNIXTIME(1344887103,'%Y-%m-%D %h:%i:%s') |

+-----------------------------------------------+

| 2012-08-14th 03:45:03 |

+-----------------------------------------------+

1 row in set (0.00 sec)


3、判断是不是同一天

SELECT tbl_gamedata.GameMapName,tbl_playerdata.GameMode, tbl_gamedata.MatchMode, tbl_playerdata.GameResult, SUM(tbl_playerdata.GameIsWin) AS tday_winCount,

SUM(tbl_playerdata.AssistCount) AS tday_assistCount,SUM(tbl_playerdata.KillCount) AS tday_killCount,

SUM(tbl_player_title.ThreeKill) AS tday_threeKill,SUM(tbl_player_title.FourKill) AS tday_fourKill,SUM(tbl_player_title.FiveKill) AS tday_fiveKill

FROM tbl_playerdata

LEFT JOIN tbl_gamedata ON tbl_playerdata.GameID = tbl_gamedata.GameID

LEFT JOIN tbl_player_title ON tbl_player_title.GameID = tbl_playerdata.GameID AND tbl_player_title.PlayerID = tbl_playerdata.PlayerID

WHERE tbl_playerdata.PlayerID = user_id

AND (tbl_playerdata.GameResult = 2 OR tbl_playerdata.GameResult = 3)

AND TO_DAYS(FROM_UNIXTIME(tbl_playerdata.GameStartTime)) = TO_DAYS(NOW())

GROUP BY tbl_gamedata.GameMapName,tbl_playerdata.GameMode,tbl_gamedata.MatchMode,tbl_playerdata.GameResult;


其中 TO_DAYS(FROM_UNIXTIME(tbl_playerdata.GameStartTime)) = TO_DAYS(NOW()) 就是我们需要的判断


4、MySQL日期获取例子

################################################################

# MySQL日期获取例子

# 01:本月第一天

# 02:本月最后一天

# 03:上月第一天

# 04:上月最后一天

# 05:下月第一天

# 06:下月最后一天

# 07:本月天数

# 08:上月今天的当前日期

# 09:上月今天的当前时间(时间戳)

# 10:获取当前时间与上个月之间的天数

# 11:前后一天日期

#

# 本月第一天

select date_add(curdate(), interval - day(curdate()) + 1 day);


# 本月最后一天

select last_day(curdate());


# 上月第一天

select date_add(curdate()-day(curdate())+1,interval -1 month);


# 上月最后一天

select last_day(date_sub(now(),interval 1 month));


# 下月第一天

select date_add(curdate()-day(curdate())+1,interval 1 month);


# 下月最后一天

select last_day(date_sub(now(),interval -1 month));


# 本月天数

select day(last_day(curdate()));


# 上月今天的当前日期

select date_sub(curdate(), interval 1 month);


# 上月今天的当前时间(时间戳)

select unix_timestamp(date_sub(now(),interval 1 month));


# 获取当前时间与上个月之间的天数

select datediff(curdate(), date_sub(curdate(), interval 1 month));


# 前后一天日期

select date_sub(curdate(),interval 1 day) as head_day,

date_sub(curdate(),interval -1 day) as later_day

from dual;


# 当前week的第一天(周日为第一天):

select date_sub(curdate(),INTERVAL WEEKDAY(curdate()) + 1 DAY);


# 当前week的最后一天(周六为最后一天):

select date_sub(curdate(),INTERVAL WEEKDAY(curdate()) - 5 DAY);


################################################################


作者:198兜兜里有糖

日期:2022年9月4日星期日

相关推荐

Linux文件系统操作常用命令(linux文件内容操作命令)

在Linux系统中,有一些常用的文件系统操作命令,以下是这些命令的介绍和作用:#切换目录,其中./代表当前目录,../代表上一级目录cd#查看当前目录里的文件和文件夹ls#...

别小看tail 命令,它难倒了技术总监

我把自己以往的文章汇总成为了Github,欢迎各位大佬star...

lnav:基于 Linux 的高级控制台日志文件查看器

lnav是一款开源的控制台日志文件查看器,专为Linux和Unix-like系统设计。它通过自动检测日志文件的格式,提取时间戳、日志级别等关键信息,并将多个日志文件的内容按时间顺序合并显示,...

声明式与命令式代码(声明模式和命令模式)

编程范式中的术语和差异信不信由你,你可能已经以开发人员的身份使用了多种编程范例。因为没有什么比用编程理论招待朋友更有趣的了,所以这篇文章可以帮助您认识代码中的流行范例。命令式编程命令式编程是我们从As...

linux中的常用命令(linux常用命令和作用)

linux中的常用命令linux中的命令统称shell命令shell是一个命令行解释器,将用户命令解析为操作系统所能理解的指令,实现用户与操作系统的交互shell终端:我们平时输入命令,执行程序的那个...

提高工作效率的--Linux常用命令,能够决解95%以上的问题

点击上方关注,第一时间接受干货转发,点赞,收藏,不如一次关注评论区第一条注意查看回复:Linux命令获取linux常用命令大全pdf+Linux命令行大全pdf...

如何限制他人操作自己的电脑?(如何控制别人的电脑不让发现)

这段时间,小猪罗志祥正处于风口浪尖,具体是为啥?还不知道的小伙伴赶紧去补一下最近的娱乐圈八卦~简单来说,就是我们的小罗同事,以自己超强的体力,以及超强的时间管理能力,重新定义了「多人运动」的含义,重新...

最通俗易懂的命令模式讲解(命令模式百科)

我们先不讲什么是命令模式,先通过一个场景来引出命令模式,看看命令模式能解决什么样的问题。现在有一个渣男张三,他有还几个女朋友,你现在是不是还是单身狗,你就说你气不气?然后他需要每天分别叫几个女朋友起床...

互联网大厂后端必看!Spring Boot 中Runtime执行与停止命令?

你是否曾在使用SpringBoot开发项目时,遇到需要执行系统命令的场景?比如调用脚本进行文件处理,又或是启动外部程序?很多后端开发人员会使用Processexec=Runtime.get...

Linux 常用命令(linux常用的20个命令面试)

日志排查类操作命令...

Java字节码指令:if_icmpgt(0xA3)(java字节码使用的汇编语言)

if_icmpgt是Java字节码中的一条条件跳转指令,其全称是"IfIntegerCompareGreaterThan"。它用于比较两个整数值的大小。如果栈顶的第一个...

外贸干货|如何增加领英的曝光量和询盘

#跨境电商#...

golang执行linux命令(golang调用shell脚本)

需求需要通过openssl生成rsa秘钥,然后保存该秘钥。代码实例packagemainimport("io/ioutil""bytes"&...

LINUX磁盘挂载(linux磁盘挂载到windows)

1、使用root用户查看磁盘挂载情况:fdisk-l2、使用df查看当前磁盘挂载情况,根据和fdisk-l的结果进行对比,查看还有那些磁盘未使用3、挂载:mount磁盘挂载路径...

Linux命令学习——nl命令(linux ln命令的使用)

nl命令主要功能为每一个文件添加行号,每一个输入的文件添加行号后发送到标准输出。当没有文件或文件为-时,读取标准输入...