在实体类里面,我们可以使用Java.sql.Date
、java.sql.Timestamp
、java.util.Date
来映射到数据库的date
、timestamp
、datetime
等字段,在Java8后,里面新出来了一些API,LocalDate
、LocalTime
、LocalDateTime
非常好用,可以用Java8 的新API替代原有的。
在MyBatis从3.4.5版本以前,Mybatis里面不支持java8的时间、日期。直接使用,会报错误。
我们需要导入相关依赖jar包,实现JSR-310相关规范
<!-- mybatis数据库字段类型映射,此处是重点 -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-typehandlers-jsr310</artifactId>
<version>1.0.1</version>
</dependency>
但是从MyBatis 3.4.5 版本开始,我们不需要导入JSR-310相关jar包,JSR-310相关规范在这个版本就已经支持了,我们可以直接使用LocalDateTime
public class User {
private LocalDateTime createTime;
// 省略 setter getter
}
public interface UserDao {
@Insert("INSERT INTO user(create_time) values(#{createTime})")
int insertUser(User user);
}
// 在set时间时,一般直接用now方法就好
public class UserDaoServiceImpl{
user.setCreateTime(LocalDateTime.now());
}
这样就OK了,如果你数据库表存的是datetime类型的话,MyBatis自动帮你解析转换,你不用做额外工作。