有如下实体类

class Stu {
    private Date birthday;
    //getter and setter
}

日期格式数据入库

对于日期格式的数据,一般前台会传入一个13位的Long类型,在Controller中使用@RequestBody可以将long类型的数据直接转换成Date类型,存入数据库时也不需要做额外的工作。

	@PostMapping("/insertStu")
    @ResponseBody
    public String insertStu(@RequestBody Stu stu) {
        stuService.insertStu(stu);
        return "OK";
    }
//Service
int insertStu(Stu stu){
	return stuMapper.insertStu(stu);
};
//Mapper
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;
    //getter and setter
}

此时,要注意JsonFormat注解是jackson的注解;JSONField注解是fastjson的注解。用谁序列化就用谁的注解。在xml中返回resultType还是resultMap对格式化不会有影响。

resultType和resultMap

  1. 如果返回的是resultType,那么select出来的列名要和实体类字段名一致。
  2. 如果返回的是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失效解决

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐