关于Java中的那些yyyy-MM-dd的问题

时间:2022-10-29 13:06:24

关于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

注意:SQL中不区分大小写,MM和mm被认为是相同的格式代码,所以Oracle的SQL采用了mi代替分钟!