@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)));
	}

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值