@JsonFormat和@DateTimeFormat注解的用法

编程入门 行业动态 更新时间:2024-10-07 22:29:36

@JsonFormat和@DateTimeFormat<a href=https://www.elefans.com/category/jswz/34/1768912.html style=注解的用法"/>

@JsonFormat和@DateTimeFormat注解的用法

使用背景

   看到Format 很容易知道就是格式转换,那么,转换的场景只有两个:一、读库 查询数据库 返回时间类型的信息到前台。二:存库 前台传给后台,然后存数据库。不管是哪一种,根据业务需求,肯定会有时间格式 不一致问题,那么转换方法肯定不是唯一的。比如 mysql 有一个函数 DATE_FORMAT(),也可以是java实现转换(simpleDateFormat),这里就只说这两个注解,怎么用。

@JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
private Date time;

注:@JsonFormat(pattern="yyyy-MM-dd",timezone = "GMT+8")

          pattern:是你需要转换的时间日期的格式

          timezone:是时间设置为东八区,避免时间在转换中有误差

解决问题:后台到前台时间格式保持一致。注意 属性类型是Date

@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private Date time;

 解决问题:@DataFormAT主要是前后到后台的时间格式的转换

拓展一下:关于mysql中 date、datetime、timestamp三者间的区别

date和datetime、timestamp的区别
date保存精度到天,格式为:YYYY-MM-DD
datetime和timestamp精度保存到秒,格式为:YYYY-MM-DD HH:MM:SS

datetime 和timestamp
两者都是时间类型字段,格式都一致。两者主要有以下几点区别:


datatime设置的是什么时间就是什么时间;timestamp则是把客户端插入的时间从当前时区转化为UTC(世界标准时间)进行存储。查询时,将其又转化为客户端当前时区进行返回。  

占用存储空间不同。timestamp储存占用4个字节,datetime储存占用8个字节。

可表示的时间范围不同。timestamp可表示范围:1970-01-01 00:00:00~2038-01-09 03:14:07,datetime支持的范围更宽1000-01-01 00:00:00 ~ 9999-12-31 23:59:59

索引速度不同。timestamp更轻量,索引相对datetime更快。

如果数据库中类型为datetime,而返回类型是string类型。会出现 返回数据 会多出“.0” 例如:2019-10-16 17:57:35.0。

这里贴一下 简单的java使用simpleDateFormat转换的工具类 

public static final String STANDARD_FORMAT = "yyyy-MM-dd HH:mm:ss";public static Date strToDate(String dateTimeStr,String formatStr){DateTimeFormatter dateTimeFormatter = DateTimeFormat.forPattern(formatStr);DateTime dateTime = dateTimeFormatter.parseDateTime(dateTimeStr);return dateTime.toDate();}public static String dateToStr(Date date,String formatStr){DateTime dateTime = new DateTime(date);return dateTime.toString(formatStr);}public static Date strToDate(String dateTimeStr){DateTimeFormatter dateTimeFormatter = DateTimeFormat.forPattern(STANDARD_FORMAT);DateTime dateTime = dateTimeFormatter.parseDateTime(dateTimeStr);return dateTime.toDate();}public static String dateToStr(Date date){DateTime dateTime = new DateTime(date);return dateTime.toString(STANDARD_FORMAT);}/*** 由时间戳转为YYYY-MM-DD格式的日期* @param time*/public static String getYmdDate3(long time){SimpleDateFormat simpleDateFormat = new SimpleDateFormat(STANDARD_FORMAT);return simpleDateFormat.format(new Date(Long.valueOf(time)));}

 

 

 

更多推荐

@JsonFormat和@DateTimeFormat注解的用法

本文发布于:2024-02-14 11:32:09,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1763432.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:注解   JsonFormat   DateTimeFormat

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!