joe 发表于 2022-5-10 10:14:33

java Date和mysql DateTime


public static Date getDateFromStamp(Timestamp timestamp) {
      //时间格式化输入输出
      SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
      String str = sdf.format(timestamp);
      try {
            Date date = sdf.parse(str);
            return date;
      } catch (ParseException e) {
            e.printStackTrace();
      }
      return null;
    }

    public static String getStrFromDate(Date signInDate) {
      SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
      return sdf.format(signInDate);
    }
特别要注意:SimpleDateFormat类是DateFormat类的子类,可以new创建实例对象。线程不安全。

joe 发表于 2022-5-10 10:20:31

和SimpleDateFormat不同的是DateTimeFormatter是线程安全的,也就是说创建一个DateTimeFormatter实例可以都处进行日期时间处理,而SimpleDateFormat只能在函数内部用局部变量处理日期时间,可参考 https://blog.csdn.net/qq_41071876/article/details/106183111

joe 发表于 2022-5-10 10:21:48

java日期格式化DateTimeFormatter前言
使用旧的Date对象时,我们用SimpleDateFormat进行格式化显示。使用新的LocalDateTime或ZonedLocalDateTime时,我们要进行格式化显示,就要使用DateTimeFormatter。

和SimpleDateFormat不同的是,DateTimeFormatter不但是不变对象,它还是线程安全的。线程的概念我们会在后面涉及到。现在我们只需要记住:因为SimpleDateFormat不是线程安全的,使用的时候,只能在方法内部创建新的局部变量。而DateTimeFormatter可以只创建一个实例,到处引用。

1、公元
G : 公元

LocalDateTime now = LocalDateTime.now();
System.out.println(now); //2020-05-17T23:24:22.012
System.out.println(now.format(DateTimeFormatter.ofPattern("G")));//公元
1
2
3
2、年
u / y / Y : 年份

LocalDateTime now = LocalDateTime.now();
System.out.println(now);//2020-05-17T23:24:22.012
System.out.println(now.format(DateTimeFormatter.ofPattern("u")));//2020
System.out.println(now.format(DateTimeFormatter.ofPattern("Y")));//2020
System.out.println(now.format(DateTimeFormatter.ofPattern("y")));//2020
1
2
3
4
5
3、月
M/L 当前年过了多少月

LocalDateTime now = LocalDateTime.now();
System.out.println(now);//2020-05-17T23:24:22.012
System.out.println(now.format(DateTimeFormatter.ofPattern("M")));//5
System.out.println(now.format(DateTimeFormatter.ofPattern("L")));//5
1
2
3
4
4、星期
E: 当日期是星期几
F:当前月过了多少星期
W :当前月过了多少星期
w : 当前年过了多少星期

LocalDateTime now = LocalDateTime.now();
System.out.println(now);//2020-05-17T23:24:22.012
System.out.println(now.format(DateTimeFormatter.ofPattern("E")));//星期日
System.out.println(now.format(DateTimeFormatter.ofPattern("yyyy年MM月dd日 E")));//2020年05月17日 星期日
System.out.println(now.format(DateTimeFormatter.ofPattern("F")));//3

1
2
3
4
5
6
5、天
D:已经过的天数
d :当前日期

LocalDateTime now = LocalDateTime.now();
System.out.println(now);//2020-05-17T23:24:22.012
System.out.println(now.format(DateTimeFormatter.ofPattern("d")));//17
System.out.println(now.format(DateTimeFormatter.ofPattern("D")));//138
1
2
3
4
6、上午或者下午
a : 上午或者下午

LocalDateTime now = LocalDateTime.now();
System.out.println(now);//2020-05-17T23:37:43.005
System.out.println(now.format(DateTimeFormatter.ofPattern("a")));//下午
1
2
3
7、 十二小时计数
h :逢0变12,范围是1-12
K :逢12变0 , 范围是0-11

LocalDateTime now1 = LocalDateTime.of(2020,1,1,0,0,0);
System.out.println(now1.format(DateTimeFormatter.ofPattern("K")));//0
System.out.println(now1.format(DateTimeFormatter.ofPattern("h")));//12

LocalDateTime now2 = LocalDateTime.of(2020,1,1,12,0,0);
System.out.println(now2.format(DateTimeFormatter.ofPattern("K")));//0
System.out.println(now1.format(DateTimeFormatter.ofPattern("h")));//12
1
2
3
4
5
6
7
8、 二十四小时计数
H :正常读,范围是0-23
k :逢0变24 , 范围是1-24

LocalDateTime now1 = LocalDateTime.of(2020,1,1,0,0,0);
System.out.println(now1.format(DateTimeFormatter.ofPattern("k")));//24
System.out.println(now1.format(DateTimeFormatter.ofPattern("H")));//0
1
2
3
7、 分钟
m : 当前小时过了多少分钟

LocalDateTime now1 = LocalDateTime.of(2020,1,1,0,2,0);
System.out.println(now1.format(DateTimeFormatter.ofPattern("m")));//2
1
2
8、秒
s :当前分钟过了多少秒

LocalDateTime now1 = LocalDateTime.of(2020,1,1,0,2,1);
System.out.println(now1.format(DateTimeFormatter.ofPattern("s")));//1
1
2
9、毫秒
A :当前秒过了多少毫秒

LocalDateTime now1 = LocalDateTime.of(2020,1,1,0,0,1);
System.out.println(now1.format(DateTimeFormatter.ofPattern("A")));//1000
1
2
10、纳秒
n :当前秒过了多少纳秒
N :当天过了多少纳秒

LocalDateTime now1 = LocalDateTime.of(2020,1,1,0,0,1);
System.out.println(now1.format(DateTimeFormatter.ofPattern("n")));//0
System.out.println(now1.format(DateTimeFormatter.ofPattern("N")));//1000000000
————————————————
版权声明:本文为CSDN博主「这是一条海鱼」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_41071876/article/details/106183111

页: [1]
查看完整版本: java Date和mysql DateTime