java时间类型的转换
我们在写代码时往往会遇到时间类型的转换问题,由于在Java中的时间是java.util.Date类型,而数据库的时间却是Java.sql.Date类型。所以,不能直接获取时间,要通过转换时间格式
前端传过去的时间格式为json字符串,在和数据库交互的时候需要转换成和数据库一致的类型
源代码
```java
package cn.wolfcode.crm.common;
import java.util.Date;
import org.springframework.format.annotation.DateTimeFormat;
import lombok.Data;
@Data
public class QueryEntity {
private String keyword;
private Date startBirthday;
private Date endBirthday;
}
package cn.wolfcode.crm.yy_persons.entity;
import java.sql.Date;
import java.util.HashMap;
import java.util.Map;
import com.alibaba.fastjson.JSON;
import com.fasterxml.jackson.annotation.JsonFormat;
import lombok.Data;
/**
*
*
* @author wcyong
*
* @date 2020-09-23
*/
@Data
public class YyPersons {
private Integer personId;
private String personName;
private String personLevel;
private Long salary;
private Date birthday;
public String getJSON() {
Map<String, Object> map=new HashMap<>();
map.put("personId", personId);
map.put("personName", personName);
map.put("personLevel", personLevel);
map.put("salary", salary);
map.put("birthday", birthday);
return JSON.toJSONString(map);
}
}
**解决办法一:
@JsonFormat与@DateTimeFormat注解的使用**
package cn.wolfcode.crm.common;
import java.util.Date;
import org.springframework.format.annotation.DateTimeFormat;
import lombok.Data;
@Data
public class QueryEntity {
private String keyword;
**//在需要转换的属性上加注解**
@DateTimeFormat(pattern="yyyy-MM-dd")
private Date startBirthday;
@DateTimeFormat(pattern="yyyy-MM-dd")
private Date endBirthday;
}
package cn.wolfcode.crm.yy_persons.entity;
import java.sql.Date;
import java.util.HashMap;
import java.util.Map;
import com.alibaba.fastjson.JSON;
import com.fasterxml.jackson.annotation.JsonFormat;
import lombok.Data;
/**
*
*
* @author wcyong
*
* @date 2020-09-23
*/
@Data
public class YyPersons {
private Integer personId;
private String personName;
private String personLevel;
private Long salary;
//在需要转换的属性上加注解
@JsonFormat(pattern = "yyyy-MM-dd")
private Date birthday;
public String getJSON() {
Map<String, Object> map=new HashMap<>();
map.put("personId", personId);
map.put("personName", personName);
map.put("personLevel", personLevel);
map.put("salary", salary);
map.put("birthday", birthday);
return JSON.toJSONString(map);
}
}
**解决方法二:
这是最省力的方法,只需将date的包换成sql即可,忽略一切与时间有关的插件**
![在这里插入图片描述](https://img-blog.csdnimg.cn/20200923211621373.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L1lpWWFuZ19za3k=,size_16,color_FFFFFF,t_70#pic_center)
因为我们对时间字段的改变就是对数据库的改变,所以我们只需要控制数据库的接口即可
**结果如下:**
![在这里插入图片描述](https://img-blog.csdnimg.cn/202009232119596.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L1lpWWFuZ19za3k=,size_16,color_FFFFFF,t_70#pic_center)