日期格式化你遇到过这样的坑吗

1,544 阅读1分钟

2022年元旦的第一天,业务群里炸开了锅,昨天导入正式库的数据,昨天导入完查询正常,今天确查不到了,这是怎么回事呢,产品,测试,开发都在群里咋呼起来,经过排查,原来是代码逻辑的问题,业务关联了年度,只能查询当年的业务,虽然是个小插曲,却让我想起了一个很容易被人遗忘的问题,就是时间格式化,YYYY-MM-dd与yyyy-MM-dd的区别。

这两个有什么区别呢,先让我们用代码运行一下看看吧

public class Test{
    public static void main(String[] args){
        Calendar calendar = Calendar.getInstance();
        calendar.set(2021, Calendar.DECEMBER, 31);
        Date date =  calendar.getTime();
        SimpleDateFormat sf1 = new SimpleDateFormat("YYYY-MM-dd");
        System.out.println("大写 YYYY: " + sf1.format(date));
        SimpleDateFormat sf2 = new SimpleDateFormat("yyyy-MM-dd");
        System.out.println("小写 yyyy: " + sf2.format(date));
    }
}

运行结果:

大写 YYYY: 2022-12-31 
小写 yyyy: 2021-12-31

是不是很奇怪,怎么同一个日期,两种格式化方式 结果却不同呢?看一下SimpleDateFormat中的解释

YYYY&yyyy.png

Y表示的是本周所属的年份,Java语言中一周从周日开始,周六结束,假如本周跨年,那么这一周获取的年份都是第二年,例如周六是2022年,周五获取的YYYY就是2022,虽然很少用YYYY对日期格式化,但是一旦遇到了也确实是一件挺尬的事情