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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 二叉树abcdefghij先序遍历_二叉树后序遍历的非递归算法

    二叉树abcdefghij先序遍历_二叉树后序遍历的非递归算法给定一个二叉树,判断其是否是一个有效的二叉搜索树。假设一个二叉搜索树具有如下特征:节点的左子树只包含小于当前节点的数。节点的右子树只包含大于当前节点的数。所有左子树和右子树自身必须也是二叉搜索树。题解深搜/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode() :

    2022年8月9日
    3
  • BC高精确度函数使用。

    BC高精确度函数使用。

    2021年9月18日
    49
  • python猪脸识别_JD竞赛,猪脸识别

    python猪脸识别_JD竞赛,猪脸识别pig_faceThisrepositoryisusedtosavethecodeforacompetition1.运行环境Ubuntu16.04python2.7.12cuda8.0cudnn6.0tensorflow1.3.0GPU4*TITANXP2.从视频中截取出猪:(1)为了排除背景数据对模型的影响,我们使用yolo-9000算法提取出视频中每一…

    2022年6月21日
    25
  • 一文搞懂反卷积,转置卷积

    一文搞懂反卷积,转置卷积一文搞懂反卷积,转置卷积前言本文翻译自《Up-samplingwithTransposedConvolution》,这篇文章对转置卷积和反卷积有着很好的解释,这里将其翻译为中文,以飨国人。如有谬误,请联系指正。转载请注明出处。联系方式:e-mail:FesianXu@163.comQQ:973926198github:https://github.com…

    2022年6月21日
    26
  • idea常用快捷键大全_idea的快捷键设置

    idea常用快捷键大全_idea的快捷键设置文章目录一.快速生成main二.快速生成System.out.print三.文件保存四.删除一行五.新添,新建,添加的快捷键六.切换java程序七.目录显示与关闭八.运行九.提示方法的参数十.切换窗口一.快速生成main输入psvm二.快速生成System.out.print使用sout三.文件保存IDEA是自动保存的,不需要我们去Ctrl+S保存。四.删除一行Ctrl+Y五.新添,新建,添加的快捷键Alt+lnsert六.切换java程序

    2022年9月6日
    5

发表回复

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

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