有如下实体类
class Stu {
private Date birthday;
}
日期格式数据入库
对于日期格式的数据,一般前台会传入一个13位的Long类型,在Controller中使用@RequestBody可以将long类型的数据直接转换成Date类型,存入数据库时也不需要做额外的工作。
@PostMapping("/insertStu")
@ResponseBody
public String insertStu(@RequestBody Stu stu) {
stuService.insertStu(stu);
return "OK";
}
int insertStu(Stu stu){
return stuMapper.insertStu(stu);
};
int insertStu(@Param("stu") Stu stu);
XML
<insert id="insertStu">
insert into stu(birthday) values (#{stu.birthday})
</insert>
日期格式查询
当我们需要查询日期信息时,一般会将其转换成宜读格式,如"yyyy-MM-dd"格式。此时可以直接在实体类字段上加上@JsonFormat(pattern = “yyyy-MM-dd”),或者@JSONField(format=“yyyy-MM-dd”)如下:
class Stu {
@JsonFormat(pattern = "yyyy-MM-dd")
private Date birthday;
}
此时,要注意JsonFormat注解是jackson的注解;JSONField注解是fastjson的注解。用谁序列化就用谁的注解。在xml中返回resultType还是resultMap对格式化不会有影响。
resultType和resultMap
- 如果返回的是resultType,那么select出来的列名要和实体类字段名一致。
- 如果返回的是resultMap,那么select出来的列名要和column一致。
<resultMap id="Stu" type="com.it.bean.Stu">
<result column="birthday" jdbcType="TIMESTAMP" property="birthday" />
</resultMap>
DateTimeFormat
DateTimeFormat可以用来接收单个参数,也可以作用于实体类的字段,可以将字符串转成日期格式。
@GetMapping("/date")
public void date(@RequestParam @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") Date date) {
System.out.println(date);
}
单个参数
在Postman中测试
实体类属性
@Data
public class Drone {
DroneStatus droneStatus;
String droneId;
@DateTimeFormat(pattern = "yyyy-MM-dd")
Date date;
}
@GetMapping("/test1")
public String test1(@RequestBody Drone droneInfo) {
return "OK";
}
参考
@JsonFormat失效解决。
|