MySQL时间戳与日期时间转换

MySQL时间戳与日期时间转换MySQL日期转时间戳:UNIX_TIMESTAMP(日期时间)MySQL时间戳转日期:FROM_UNIXTIME(时间戳,日期时间格式);

大家好,又见面了,我是你们的朋友全栈君。

时间戳与日期时间转换

参考:mysql 将时间戳直接转换成日期时间 – snn1410

-- 1、将时间戳转换为日期时间
SELECT FROM_UNIXTIME( 1585108245.567);
运行结果:2020-03-25 11:50:45.567

-- 也可以使用修饰符自定义格式
SELECT FROM_UNIXTIME( 1585108245.567,'%Y年%m月%d日 %H时%i分%S秒 %f');
运行结果: 20200325115045567000  --详解下翻

-- 2、若时间戳为负数,该方法的结果为null值
select FROM_UNIXTIME(-2);
运行结果:null

-- 解决方法:使用函数 DATE_ADD(date,INTERVAL expr type);
select DATE_ADD(FROM_UNIXTIME(0),INTERVAL -2 SECOND);
运行结果:1970-01-01 07:59:58  --详解下翻
-- 将日期转换为时间戳
select UNIX_TIMESTAMP('2020-03-25 11:11:45');
运行结果: 1585105905

-- 其无参方法将当前系统时间转换为时间戳
select UNIX_TIMESTAMP();
运行结果: 1585108852

详细:
FROM_UNIXTIME()函数,具体如下

  • FROM_UNIXTIME(unix_timestamp,format) 返回表示 Unix 时间标记的一个字符串,根据format字符串格式化。
  • 下列修饰符可以被用在format字符串中(粗体为常用):
修饰符 含义 值例举
%Y 年,4 位数字 2019
%y 年,后 2 位数字 19
%M 月,英文名 January……December
%m 月,数字,不足两位数补0 01……12
%b 月,英文缩写 Jan……Dec
%c 月,数字 1……12
%D 日,英文序数 1st、2nd、3rd、
%d 日,数字,不足两位数补0 00……31
%e 日,数字 0……31
%j 一年中的第n天,不足三位数补0 001……366
%W 星期,英文名 Sunday……Saturday
%w 星期,数字 0=Sunday ……6=Saturday
%a 星期,英文缩写 Sun……Sat
%U 一年中的第n星期 0……52,这里星期天是星期的第一天
%u 一年中的第n星期 0……52,这里星期一是星期的第一天
%H 时,24时制,不足两位数补0 00……23
%h 时,12时制,不足两位数补0 01……12
%k 时,24时制 0……23
%I (大写的 i) 时,12时制,不足两位数补0 01……12
%l (小写的 L) 时,12时制 1……12
%i 分,数字,不足两位数补0 00……59
%S 秒,不足两位数补0 00……59
%f 毫秒,不足6位补0 0.000000 …… 0.999999
%s 秒,不足两位数补0 00……59
%p AM或PM
%r 时间,12小时制 hh:mm:ss [AP]M
%T 时间,24小时制 hh:mm:ss
%% 字符“%”

DATE_ADD()函数,具体如下

  • DATE_ADD(date,INTERVAL expr type),该函数可以得到在原有的日期时间上增加一段时间后的日期时间。
  • date参数为日期时间格式的数据;
  • INTERVAL为关键字;
  • type为时间单位。
  • 在上面的SQL例子中,即为在基准时刻 1970-01-01 08:00:00 的基础上加上 -2 秒,得到了时刻 1970-01-01 07:59:58
  • 关于基准时刻需要注意,它是根据不同时区来设定的。我们国内是使用的东八区的时区,所以基准时刻是08:00:00,若是在0时区,则基准时刻为00:00:00。至于MySQL数据库是根据哪里判断的时区,还不清楚,以后补充。

参考:
Mysql中处理1970年前的日期(unixtime为负数的情况)负数时间戳格式化 – 与f

type值 预期的expr格式
MICROSECOND 整数
SECOND 整数
MINUTE 整数
HOUR 整数
DAY 整数
WEEK 整数
MONTH 整数
QUARTER 整数(季节)
YEAR 整数
SECOND_MICROSECOND ‘秒.毫秒’
MINUTE_MICROSECOND ‘分钟数.毫秒’
MINUTE_SECOND ‘分:秒’
HOUR_MICROSECOND ‘小时数.毫秒’
HOUR_SECOND ‘时:分:秒’
HOUR_MINUTE ‘时:分’
DAY_MICROSECOND ‘日期号数.毫秒’
DAY_SECOND ‘日 时:分:秒’
DAY_MINUTE ‘日 时:分’
DAY_HOUR ‘日 小时’
YEAR_MONTH ‘年-月’
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/151927.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月21日 上午11:36
下一篇 2022年6月21日 上午11:36


相关推荐

  • vs python生成exe文件_使用VScode编写python程序并打包成.exe文件

    vs python生成exe文件_使用VScode编写python程序并打包成.exe文件据说VisualStudioCode(VSCode)的诸多好处,了解了一下果然很喜欢,我喜欢它的原因主要有3个,一是VSCode开源且跨平台,二是因为其界面非常酷,三是可以满足我的大所属代码需求,除此之外当然还有强大的好奇心。使用VScode编写第一个Python程序“one.py”,并将其打包成.exe文件。演示使用的程序版本:python36,VScode1.27.1,pyinstal…

    2022年5月15日
    61
  • 搭建简单的Eurake服务学习笔记

    搭建简单的Eurake服务学习笔记搭建简单的Eureka服务简单介绍Eureka原理:Eureka集群主要有三个部分Eureka服务器,服务提供者,服务调用者简单的来说就是服务提供者将服务注册到Eureka服务器,服务调用者对其服务进行查找调用。搭建三个项目:创建三个SpringStarterProject类型的项目:[外链图片转存失败(img-aVuiN1EV-1563345334382)(file://…

    2022年5月24日
    43
  • 2022最新手机号码正则

    2022最新手机号码正则2022最新手机号码正则

    2022年5月31日
    87
  • 二、快速开始——Spring集成Mybatis-Plus

    二、快速开始——Spring集成Mybatis-Plus由于MyBatis-Plus是在MyBatis的基础上只做增强不做改变,因此其与Spring的整合非常简单。只需把MyBatis的依赖换成MyBatis的依赖,再把sqlSessionFactory换成MyBatis-Plus的即可。下面让我们在Spring中快速集成Mybatis-Plus的具体操作:1、准备测试表–创建库CREATEDATABASEmp;–使用库USEm…

    2022年5月20日
    82
  • 网站管理后台帐号密码暴力激活成功教程方法

    网站管理后台帐号密码暴力激活成功教程方法【导读】对于网站运行的个人站长而言,最担心的是应如何有效且安全的去管理自己的网站,否则自己辛辛苦苦经营的网站就会被不请自来的不速之客给攻破,轻则站点数据被窃取,重则整个网站都被攻陷,导致无法恢复。本文主要从管理后台这个方面来讲解其黑客攻击过程,并通过在虚拟环境中展开实例演示,各读者可以跟着本教程去做实验,通过实验加强对攻击过程的了解,如果你是一名菜鸟站长也可以针对性的去做一下防护方案。…

    2022年8月22日
    9
  • 什么是2MSL

    什么是2MSL转自 什么是 2MSL 保存在此以学习 MSL 是 MaximumSegme 英文的缩写 中文可以译为 报文最大生存时间 他是任何报文在网络上存在的最长时间 超过这个时间报文将被丢弃 因为 tcp 报文 segment 是 ip 数据报 datagram 的数据部分 具体称谓请参见 数据在网络各层中的称呼 一文 而 ip 头中有一个 TTL 域 TTL 是 timetolive 的缩写 中文可

    2026年3月18日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号