问题起因
主要是使用mybatis作为ORM之后,返回的对象为Map,然后对于数据库的datetime,datestamp类型返回为时间戳而不是标准的时间,这个问题解决方案有两种,大叔分析一下:
1.在mapper的select里,使用mysql这些数据库的函数,dateformat进行转化,缺点,单元测试里使用h2数据库时会找不到这些函数
2.在 Mapper反序列化时统一进行处理,这种方式更好,与具体数据库解耦了
实现
>引用依赖包
'org.mybatis:mybatis-typehandlers-jsr310:1.0.2', 'com.faster .jackson.datatype:jackson-datatype-jsr310:2.9.2'
>添加组件类
/**
* 序列化localdatetime处理.
*/
@Component
public class JacksonConfig {
/**
* 注入时间处理.
*
* @return
*/
@Bean
@Primary
public Mapper Mapper() {
Mapper mapper = new Mapper();
mapper.registerModule(new JSR310Module());
mapper.setDateFormat(new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSS'Z'"));
return mapper;
}
}
>成功解决问题
{
"pageCurrent": 1,
"pageSize": 10,
"pageTotal": 1,
"data": [
{
"freeDays": 8,
"city": "",
"leadingPerson": "",
"contactPerson": "zhangsan",
"source": 1,
"customerName": "i-counting",
"intention": 1,
"province": "",
"appointmentTime": "2018-09-20T00:00:00.000Z",
"createTime": "2018-09-27T06:33:49.000Z",
"telephoneStatus": 1,
"id": 10000,
"contactPhone": "135"
}
]
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
继续阅读与本文标签相同的文章
下一篇 :
java对同一个文件进行读写操作方法
-
711便利店:日本计划关店1000家,母公司将裁员3000人
2026-05-18栏目: 教程
-
阿里云服务器共享型实例xn4 n4 性价比高适合个人博客 中小型网站
2026-05-18栏目: 教程
-
QQ上这3个隐藏功能,“偷偷”告诉谁在暗恋你,不准不要你钱
2026-05-18栏目: 教程
-
戴森电动汽车梦破碎 业内人士:及时止损明智之举
2026-05-18栏目: 教程
-
SpaceX提交3万颗Starlink宽带星座卫星发射申请
2026-05-18栏目: 教程
