sql中的时间范围查询【三种方式】以及Mapper.xml中遇到大于号小于号问题解决方案
作者:mmseoamin日期:2023-12-05
select * from test_case where create_time >= '2023-8-28 00:00:00' and create_time <= '2023-8-28 23:59:59';
select * from test_case where create_time >= '#{startTime} 00:00:00' and create_time <= '#{endTime} 23:59:59';
select * from test_case where STR_TO_DATE(create_time, '%Y-%m-%d') >= '2023-8.28' AND STR_TO_DATE(create_time, '%Y-%m-%d') <= '2023-8.28'

mapper注意事项

字符转义字符描述
>>大于
>=>=大于等于
<<小于
<=<=小于等于
""双引号
'单引号
&&and

遇到问题:

从数据库获取时间传到前端进行展示的时候,我们有时候可能无法得到一个满意的时间格式的时间日期,在数据库中显示的是正确的时间格式,获取出来却变成了很丑的时间戳,@JsonFormat注解很好的解决了这个问题,我们通过使用@JsonFormat可以很好的解决:后台到前台时间格式保持一致的问题,其次,另一个问题是,我们在使用WEB服务的时,可能会需要用到,传入时间给后台,比如注册新用户需要填入出生日期等,这个时候前台传递给后台的时间格式同样是不一致的,而我们的与之对应的便有了另一个注解,@DataTimeFormat便很好的解决了这个问题,

Cannot deserialize value of type `java.util.Date` from String

实体类中添加

@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone="GMT+8")
private Date createTime;
  • 注解@JsonFormat主要是后台到前台的时间格式的转换

    这里解释一下:@JsonFormat(timezone=“GMT+8”, pattern=“yyyy-MM-dd”)

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

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