常用格式为:yyyy-MM-dd HH:mm:ss

以 2019-12-31 06:07:59:666 时间为例:

字符

含义

Example

y(小写的y)

yyyy—->2019

M(大写的M)

MM—->12

d(小写的d)

一月中的天数

dd—->31

H(24 小时制,大写的H)

小时(0-23)

HH—->18

h(12 小时制,小写的h)

小时(1-12)

hh—->06

m(小写的m)

mm—->07

s(小写的s)

ss—->59

S(大写的S)

毫秒

SSS—->666

Y(大写的y)

Week Year

YYYY—->2020

D(大写的D)

一年中天数

DD—->365

yyyy-MM-dd与YYYY-MM-dd区别在哪里?

Y 代表 Week Year,表示当天周所在的年份。这种方式将会把一年划分成52 周/53周(类似于闰年的概念,每隔几年将会增加一周)。Week Year下每周仅属于某一年,如果某年的第一周或最后一周跨年,就会导致部分日期年份与实际不符。

Week Year 存在两种标准:

ISO 8601:国际标准,每周从周一开始,每年的第一周至少包含 4 天

Common:通用标准,每周从周日开始,每年的第一周至少包含 1 天

使用 ISO 8601 标准,分别看一下最后一周跨年以及第一周跨年的例子。

2015 年最后一周跨年,2016 前三天(与2015年12月的前四天默认是一周,是2015的周)使用 YYYY 最后结果为 2015,时间看起来被回退了。

2020 年第一周跨年,2019 年最后两天(不足4天,所以默认为下周,下周为2020年的周)使用 YYYY 结果为 2020。

代码验证

import com.sun.org.apache.xerces.internal.impl.xpath.regex.ParseException;import java.text.SimpleDateFormat;import java.util.Date;public class Demo {public static void main(String[] args) {// 将指定时间转换成时间戳,再由时间戳转换成时间String Stime = "2015-01-01 17:17:22"; // 处理前的时间long Ltime = 0; // 时间戳System.out.println("处理前的时间:" + Stime);// 时间转为时间戳SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");try {Date date2 = simpleDateFormat.parse(Stime);Ltime = date2.getTime();System.out.println("时间转时间戳结果:" + Ltime);} catch (ParseException | java.text.ParseException e) {e.printStackTrace();}//将时间戳转换为时间String res = simpleDateFormat.format(Ltime);System.out.println("时间戳转时间结果:" + res);}}

运行结果:

处理前的时间:2015-01-01 17:17:22

时间转时间戳结果:1420103842000

时间戳转时间结果:2015-01-01 17:17:22

可以看出两次时间是一样的。

将代码中的yyyy改为YYYY后

SimpleDateFormat simpleDateFormat = new SimpleDateFormat(“yyyy-MM-dd HH:mm:ss”);

运行结果:

处理前的时间:2015-01-01 17:17:22

时间转时间戳结果:1419758242000

时间戳转时间结果:2015-12-28 17:17:22

可以看出两次时间不是一样的。

oracle和java的日期格式的差异

java中的的日期格式为:

yyyy-MM-dd HH:mm:ss:代表将时间转换为24小时制,例: 2020-01-07 13:21:55

yyyy-MM-dd hh:mm:ss:代表将时间转换为12小时制,例: 2020-01-07 03:24:21

oracle中的日期格式为(不区分大小写):

yyyy-MM-dd HH24:mi:ss:代表oracle中的24小时制,例:2020/1/7 13:21:55

yyyy-MM-dd HH:mi:ss: 代表oracle中的12小时制,例:2020/1/7 9:21:55

之所以 oracle和java不同,是因为我们知道oracle是不区分大小写的,所以java中根据大小写来代表24小时和12小时的表达式在oracle中就会出问题,oracle中将24小时的时和分做了特殊处理.如上所示,在hh后面加上了24,将mm改为了mi.

大部分内容转载自: 关于日期格式你必须知道的坑( yyyy-MM-dd HH:mm:ss SSS)_yyyy-mm-dd hh:mm:ss.sss_37358143的博客-CSDN博客