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

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

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

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日星期日

相关推荐

VPS主机搭建Ghost环境:Nginx Node.js MariaDB

Ghost是一款个人博客系统,它是使用Node.js语言和MySQL数据库开发的,同时支持MySQL、MariaDB、SQLite和PostgreSQL。用户可以在支持Node.js的服务器上使用自己...

centos7飞速搭建zabbix5.0并添加windows、linux监控

一、环境zabbix所在服务器系统为centos7,监控的服务器为windows2016和centos7。二、安装zabbix官方安装帮助页面...

Zabbix5.0安装部署

全盘展示运行状态,减轻运维人员的重复性工作量,提高系统排错速度,加速运维知识学习积累。1.png...

MariaDB10在CentOS7系统下,迁移数据存储位置

背景在CentOS7下如果没有默认安装MySQL数据库,可以选择安装MariaDB,最新的版本现在是10可以选择直接yum默认安装的方式yum-yinstallmariadbyum-yi...

frappe项目安装过程

1,准备一台虚拟机,debian12或者ubuntusever22.04.3可以用virtualbox/qemu,或者你的超融合服务器安装一些常用工具和依赖库我这里选择server模式安装,用tab...

最新zabbix一键安装脚本(基于centos8)

一、环境准备注意:操作系统必须是centos8及以上的,因为我配的安装源是centos8的。并且必须连接互联网,脚本是基于yum安装的!!!...

ip地址管理之phpIPAM保姆级安装教程 (原创)

本教程基于Ubuntu24.04LTS,安装phpIPAM(最新稳定版1.7),使用Apache、PHP8.3和MariaDB,遵循最佳实践,确保安全性和稳定性。一、环境准备1....

centos7傻瓜式安装搭建zabbix5.0监控服务器教程

zabbix([`zaebiks])是一个基于WEB界面的提供分布式系统监视...

zabbix7.0LTS 保姆级安装教程 小白也能轻松上手安装

系统环境:rockylinux9.4(yumupdate升级到最新版本)数据库:mariadb10.5.22第一步:关闭防火墙和selinux使用脚本关闭...

ubuntu通过下载安装包安装mariadb10.4

要在Ubuntu18.04上安装MariaDB10.4.34,用的是那个tar.gz的安装包。步骤大概是:...

从0到1:基于 Linux 快速搭建高可用 MariaDB Galera 集群(实战指南)

在企业生产环境中,数据库的高可用性至关重要。今天带你从0到1,手把手在Linux系统上快速搭建一个高可用MariaDBGaleraCluster,实现数据库同步复制、故障自动恢复,保障业务...

Windows 中安装 MariaDB 数据库

mariadb在Windows下的安装非常简单,下载程序双击运行就可以了。需要注意:mariadb和MySQL数据库在Windows下默认是不区分大小写的,但是在Linux下是区分...

SQL执行顺序(SqlServer)

学习SQL这么久,如果突然有人问你SQL的执行顺是怎么样的?是不是很多人会觉得C#、JavaScript都是根据编程顺序来处理的,那么SQL也是根据编程顺序来执行的吗?...

C# - StreamWriter与StreamReader 读写文件 101

读写文本文件的方式:1)File静态类的File.ReadAllLines();与File.WriteAllLines();方法进行读写...

C#中的数组探究与学习

C#中的数组一般分为:...