原因:mybatis plus3.X的代码生成器默认生成时间类型为LocalDateTime,当从数据局进行连接查询时通常需要定义返回类型为Map,这样返回的时间格式经常如下面所示
"createTime": "2018-09-25T17:40:35",
"updateTime": "2018-09-25T17:40:35",
"paymentTime": "2018-09-25T17:40:35",
"transactionTime": "2018-09-25T17:40:35.576z",
这是mybatis plus3.X当我们对时间类型进行查询时自动进行的封装
我的思路:不使用默认Map,自定义map,当put到timestrap类型的数据时,格式化为yyyy-MM-dd HH:mm:ss类型,下面是我自定义的RMap
package cn.xb.common;
import java.sql.Timestamp;
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;
import org.apache.commons.collections.map.HashedMap;
public class RMap extends HashedMap {
private static final long serialVersionUID = 1L;
@Override
public Object put(Object key, Object value) {
if(value != null) {
String type = value.getClass().getSimpleName();
if(type.equals("Timestamp")) {
Timestamp times = (Timestamp) value;
LocalDateTime time = times.toLocalDateTime();
String format = time.format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"));
return super.put(key, format);
}else {
return super.put(key, value);
}
}
return super.put(key, value);
}
}
然后是mapper.xml文件中返回值的定义
完美解决返回格式的问题,最重要的是这样一种思路,自定义Map来实现对所有返回类型的格式转换
last but not least,when you don’t know the real type of the database return,please do a breakpoint to debug
当你不知道数据库实际返回值类型时候,记得打一个断点来看看实际的返回值类型,像下图这样,在获取返回值的下一行打上断点,这样你就可以知道从数据库返回的值经mybatis包装后的实际类型了
我觉得本篇博客想展示给大家的更多的是这样一种思路,如果你感觉我的文章挺好,麻烦点个赞喽,创作也是需要热情的,非常感谢!!