map key为null_mybatis json

map key为null_mybatis jsonmybatis返回Map结果集value为Null的情况下丢失key的解决办法本博主之前一直是网络资源的索取者,本着开源精神愿意把自己在开发过程中遇到过的问题以及解决方案分享给大家,这是我的第一篇博客,希望以后能坚持写博客,让大家少走弯路、少踩坑。废话少说,直入主题!springcloud微服务集成mybatis动态多数据源在网上有很多文章可以搜到,这里就不重复造轮子了。如题,网上…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

mybatis返回Map结果集value为Null的情况下丢失key的解决办法

本博主之前一直是网络资源的索取者,本着开源精神愿意把自己在开发过程中遇到过的问题以及解决方案分享给大家,这是我的第一篇博客,希望以后能坚持写博客,让大家少走弯路、少踩坑。
废话少说,直入主题!
springcloud微服务集成mybatis动态多数据源在网上有很多文章可以搜到,这里就不重复造轮子了。
如题,网上的很多解决方案比如:
尝试在application.yml 文件中配置 mybatis:callSettersOnNulls:true,对于springboot启动加载yml的单一数据源是有效的,但是在动态多数据源的情况下,是需要自己手动增加数据源配置类:DataSourceConfig.java,并且需要在启动类加上了@SpringBootApplication(exclude ={DataSourceAutoConfiguration.class})注解。
因此,上述解决方案就没用了,下面给出我的解决方案,亲测有效:
1.xml文件

<mapper namespace="com.jess.order.dao.extend.VersionExtendMapper" >
  <resultMap id="baseResultMap" type="java.util.LinkedHashMap">
    <result property="id" column="id" />
    <result property="name" column="name" />
    <result property="versionNo" column="version_no" />
    <result property="createtime" column="create_time" />
    <result property="updatetime" column="update_time" />
  </resultMap>

  <select id="find" resultMap="baseResultMap" >
    select * from com_version
  </select>

如上,返回的map格式如下:
“data”: [
{
“id”: 1,
“name”: “版本名称1”,
“versionNo”: “版本号1”,
“createtime”: “2018-09-08 10:22:24”,
“updatetime”: “2018-09-08 10:33:54”
},
{
“id”: 2,
“name”: “版本名称2”,
“versionNo”: “版本号2”,
“createtime”: “2018-09-08 10:22:24”,
“updatetime”: “2018-09-08 10:33:54”
}]
如果数据库对应的id=1的字段version_no的值是Null,那么就会出现下面的情况:
“data”: [
{
“id”: 1,
“name”: “版本名称1”,
“createtime”: “2018-09-08 10:22:24”,
“updatetime”: “2018-09-08 10:33:54”
},
{
“id”: 2,
“name”: “版本名称2”,
“versionNo”: “版本号2”,
“createtime”: “2018-09-08 10:22:24”,
“updatetime”: “2018-09-08 10:33:54”
}]
也就是说Map中的key丢失了,在前后端分离的项目中,前端获取丢失的字段直接报错!
这个问题困扰了我好几天,阅读源码后总算是解决了问题,方案如下:
修改DataSourceConfig.java文件

@Bean
    public SqlSessionFactory sqlSessionFactory(DataSource dynamicDataSource) throws Exception {
        SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
        bean.setDataSource(dynamicDataSource);
        bean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath*:mapper/**/**.xml"));
        **org.apache.ibatis.session.Configuration config = bean.getObject().getConfiguration();
        config.setCallSettersOnNulls(true);
        bean.setConfiguration(config);**
        return bean.getObject();
    }

上述代码加粗的字体中:config.setCallSettersOnNulls(true);表示设置结果为Null也返回相应的字段名称。就这么简单,解决了!so easy

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/188269.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 惠普硬盘型号怎么看_惠普电脑序列号查询真伪

    惠普硬盘型号怎么看_惠普电脑序列号查询真伪大家都知道电脑使用起来非常方便,但遇见硬盘序列号怎么看的时候就非常头疼了,如果你是第一次遇到硬盘序列号怎么看,怎么样才能快速解决硬盘序列号怎么看带来的烦恼呢?小编为大家收集了很多关于硬盘序列号怎么看问题的解决方法,下面请看具体的解决方法步骤:如何查看电脑硬盘序列号问:惠普电脑的XP系统答:第一步单击【开始】→【运行…】,输入cmd第二步输入diskpart,按回车键第三步输入list…

    2022年8月13日
    14
  • fastjson把map转json_fastjson转list对象

    fastjson把map转json_fastjson转list对象Stringtest=”jdkalkjda|||djkdla|||djlak”;Stringstr[]=test.split(“\\|\\|\\|”);System.out.println(str.length);HashMapt=newHashMap();HashMapt1=newHashMap();t1.put(“k”,”3″);Objects1=JSONObj…

    2022年10月4日
    3
  • spring aop实例讲解_abaqus实例详解pdf

    spring aop实例讲解_abaqus实例详解pdfSpringAOP原理详解及实例1.SpringAOP简介在软件业,AOP为AspectOrientedProgramming的缩写,意为:面向切面编程,通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术。AOP是OOP的延续,是软件开发中的一个热点,也是Spring框架中的一个重要内容,是函数式编程的一种衍生范型。利用AOP可以对业务逻辑的各个部分进行隔离,从而使得业务逻…

    2022年8月11日
    7
  • 直接计算下面两个序列的卷积和_快速解锁键盘是哪个键

    直接计算下面两个序列的卷积和_快速解锁键盘是哪个键算法70—-只有两个键的键盘【动态规划】

    2022年4月21日
    52
  • 环信-(php)服务器端REST API

    环信-(php)服务器端REST API

    2021年11月9日
    42
  • 推荐三款免费可外链网络相册「建议收藏」

    推荐三款免费可外链网络相册「建议收藏」现在很多的论坛都不提供上传的空间或者有诸多限制,如果我们想要在论坛中贴照片的话就得先找一个网络相册,然后以外链的方式才能贴出图片,可是现在主流的163相册,QQ和51等相册都无法支持图片外链,你是否还在苦苦寻找一个好的可以外链的相册呢?今天我就为大家带来三款提供免费外链的网络相册,希望能帮助大家解决难题。三款外链网络相册:1、Swode相册http://www.swode….

    2022年6月16日
    34

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号