springboot2.X整合mybatis plus3.XJDK8环境下返回值为Map时间格式的规格化

9 篇文章 0 订阅
6 篇文章 0 订阅

原因: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包装后的实际类型了

在这里插入图片描述

我觉得本篇博客想展示给大家的更多的是这样一种思路,如果你感觉我的文章挺好,麻烦点个赞喽,创作也是需要热情的,非常感谢!!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值