关于java中的java.text.SimpleDateFormat相信大家并不陌生,我们通常使用它来格式化日期,比较好用,但是对于它里面的年月日时分秒实在是记不清,在这里笔者就缕一缕这里的关系
字母 | 日期或时间元素 | 表示 | 示例 |
---|---|---|---|
G |
时代 标志符 | Text | AD |
y |
年 | Year |
1996 ; 96
|
M |
年中的月份 | Month |
July ; Jul ; 07
|
w |
年中的周数 | Number | 27 |
W |
月份中的周数 | Number | 2 |
D |
年中的天数 | Number | 189 |
d |
月份中的天数 | Number | 10 |
F |
月份中的星期 | Number | 2 |
E |
星期中的天数 | Text |
Tuesday ; Tue
|
a |
Am/pm 标记 | Text | PM |
H |
一天中的小时数(0-23) | Number | 0 |
k |
一天中的小时数(1-24) | Number | 24 |
K |
am/pm 中的小时数(0-11) | Number | 0 |
h |
am/pm 中的小时数(1-12) | Number | 12 |
m |
小时中的分钟数 | Number | 30 |
s |
分钟中的秒数 | Number | 55 |
S |
毫秒数 | Number | 978 |
z |
时区 | General time zone |
太平洋标准时间 ; PST ; GMT-08:00
|
Z |
时区 | RFC 822 time zone | -0800 |
具体使用见代码
import java.text.SimpleDateFormat; import java.util.Date; public class DateFormat { public static void main(String[] args) { Date rightNow = new Date(); java.text.DateFormat format1 = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss"); java.text.DateFormat format2 = new SimpleDateFormat("y-M-d H:m:s"); java.text.DateFormat format3 = new SimpleDateFormat("yyyy-MM-dd"); java.text.DateFormat format4 = new SimpleDateFormat("h:mm a"); java.text.DateFormat format5 = new SimpleDateFormat("yyyy.MM.dd G 'at' HH:mm:ss z"); java.text.DateFormat format6 = new SimpleDateFormat("EEE, MMM, dd, ''yyyy"); java.text.DateFormat format7 = new SimpleDateFormat("yyyy.MM.dd kk:mm 'o''clock' a, zzzz"); java.text.DateFormat format8 = new SimpleDateFormat("yyyyy.MMMMM.dd GGG hh:mm aaa"); System.out.println("format1 = " + format1.format(rightNow)); System.out.println("format2 = " + format2.format(rightNow)); System.out.println("format3 = " + format3.format(rightNow)); System.out.println("format4 = " + format4.format(rightNow)); System.out.println("format5 = " + format5.format(rightNow)); System.out.println("format6 = " + format6.format(rightNow)); System.out.println("format7 = " + format7.format(rightNow)); System.out.println("format8 = " + format8.format(rightNow)); } }
结果:
format1 = 2017-03-14 09:22:58 format2 = 2017-3-14 9:22:58 format3 = 2017-03-14 format4 = 9:22 上午 format5 = 2017.03.14 公元 at 09:22:58 CST format6 = 星期二, 三月, 14, '2017 format7 = 2017.03.14 09:22 o'clock 上午, 中国标准时间 format8 = 02017.三月.14 公元 09:22 上午
从此可以看出:yyyy表示年的占位符 有几个y就一定有几位数字组成的年 如果只有一个y则显示当前的完整年份,如果是MM代表两位的月比如03月12月等,只有一个M则为12月3月等
以此类推
记得有一次面试 面试官问我sql中格式化日期的方法我答的to_date()面试官问我sql里的mm与MM的区别用法 还真难倒我了 sql里的这个与Java的并不一样、
对于MySQL中的日期格式化:
获取系统日期: NOW()
格式化日期: DATE_FORMAT(date, format)
返回系统日期,输出 2017-03-14 09:38:59
select now(); 或者 select sysdate();
输出 17-03-14
select date_format(now(),'%y-%m-%d');
根据format字符串格式化date值:
%S, %s 两位数字形式的秒( 00,01, ..., 59)
%I, %i 两位数字形式的分( 00,01, ..., 59)
%H 两位数字形式的小时,24 小时(00,01, ..., 23)
%h 两位数字形式的小时,12 小时(01,02, ..., 12)
%k 数字形式的小时,24 小时(0,1, ..., 23)
%l 数字形式的小时,12 小时(1, 2, ..., 12)
%T 24 小时的时间形式(hh:mm:ss)
%r 12 小时的时间形式(hh:mm:ss AM 或hh:mm:ss PM)
%p AM或PM
%W 一周中每一天的名称(Sunday, Monday, ..., Saturday)
%a 一周中每一天名称的缩写(Sun, Mon, ..., Sat)
%d 两位数字表示月中的天数(00, 01,..., 31)
%e 数字形式表示月中的天数(1, 2, ..., 31)
%D 英文后缀表示月中的天数(1st, 2nd, 3rd,...)
%w 以数字形式表示周中的天数( 0 = Sunday, 1=Monday, ..., 6=Saturday)
%j 以三位数字表示年中的天数( 001, 002, ..., 366)
%U 周(0, 1, 52),其中Sunday 为周中的第一天
%u 周(0, 1, 52),其中Monday 为周中的第一天
%M 月名(January, February, ..., December)
%b 缩写的月名( January, February,...., December)
%m 两位数字表示的月份(01, 02, ..., 12)
%c 数字表示的月份(1, 2, ...., 12)
%Y 四位数字表示的年份
%y 两位数字表示的年份
%% 直接值“%”
对于oracle中的日期格式化
获取系统日期: SYSDATE()
格式化日期: TO_DATE(date, format)
转换的格式:
表示year的:y 表示年的最后一位 yy 表示年的最后2位 yyy 表示年的最后3位 yyyy 用4位数表示年
表示month的:mm 用2位数字表示月 mon 用简写形式
表示day的:dd 表示当月第几天;ddd表示当年第几天;dy 当前周第几天 简写 day
表示hour的:hh 2位数表示小时 12进制; hh24 2位数表示小时 24小时
表示minute的:mi 2位数表示分钟
表示second的:ss 2位数表示秒 60进制
表示季度的:q 一位数 表示季度 (1-4)
另外还有ww 用来表示当年第几周 w用来表示当月第几周。
24小时制下的时间范围:00:00:00-23:59:59
12小时制下的时间范围:1:00:00-12:59:59
比如:
select to_char(sysdate,'yy-mm-dd hh24:mi:ss') from dual //显示:17-03-14 09:22:42
补充:
当前时间减去7分钟的时间
select sysdate,sysdate - interval '7' MINUTE from dual
当前时间减去7小时的时间
select sysdate - interval '7' hour from dual
当前时间减去7天的时间
select sysdate - interval ’7’ day from dual
当前时间减去7月的时间
select sysdate,sysdate - interval '7' month from dual
当前时间减去7年的时间
select sysdate,sysdate - interval '7' year from dual
时间间隔乘以一个数字
select sysdate,sysdate - 8*interval '7' hour from dual