java时间类型的转换

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)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值