在次之前我先声明一下我在这里遇到的一个大坑:就是时区的问题,所有条件,都能在控制台看出来,前后台也不报错的情况下,那么就证明你的代码没有问题,问题出在时区的那块!
我的这次时区问题,是因为数据版本导致的,5点几的一般不会出现,就是因为版本原因导致的时区不同,我的环境是mysql8.0+连接器8.0,之前设置的是UTC时区,改完后设置成Asia/Shanghai就完美解决!
这块我整理一下关于时间的一些配置:
我的dao、mapper、vo是通过mybatis逆向工程生成的,标红的是针对生成query文件里的函数说的
一、jsp页面对于日期格式的显示和传值
<input name="orderdate" type="date" value="<fmt:formatDate value="${orderdate}" pattern="yyyy-MM-dd" type="date"/>"/>
二、运行框架后出现日期不能为空的错误
在controller里面加上这一条,表示在当前类里不会出现问题
@InitBinder public void init(WebDataBinder binder) { binder.registerCustomEditor(Date.class, new CustomDateEditor(new SimpleDateFormat("yyyy-MM-dd"), true)); }
但是这里注意,日期类型的数据没有模糊查询,所以参数传进andOrderflagEqualTo()里必须不能是null值,所以用次函数之前需要判断一下后台传过来的日期是否为空
if(bz.getOrderdate()!=null){ criteria.andOrderdateEqualTo(bz.getOrderdate()); }
三、时间格式处理注解
@DateTimeFormat(pattern = "yyyy-MM-dd"):该注解放在实体类里的属性上面,
@@JsonFormat(pattern = "yyyy-MM-dd",timezone = "UTC"):该注解加在实体类中的日期类型上,可以将返回的Json字符串中的时间戳转换为具体时间
使用原因:
从数据库获取时间传到前端进行展示的时候,我们有时候可能无法得到一个满意的时间格式的时间日期,在数据库中显示的是正确的时间格式,获取出来却变成了很丑的时间戳,@JsonFormat注解很好的解决了这个问题,我们通过使用@JsonFormat可以很好的解决:后台到前台时间格式保持一致的问题,其次,另一个问题是,我们在使用WEB服务的时,可能会需要用到,传入时间给后台,比如注册新用户需要填入出生日期等,这个时候前台传递给后台的时间格式同样是不一致的,而我们的与之对应的便有了另一个注解,@DataTimeFormat便很好的解决了这个问题,