注解的用法"/>
@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注解的用法
发布评论