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

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • Python_note_003(Python中的输入函数input()、运算符用法)「建议收藏」

    Python_note_003(Python中的输入函数input()、运算符用法)「建议收藏」输入函数input()作用:接收来自用户的输入返回值类型:输入值的类型为str值的存储:使用=对输入的值进行存储#输入函数inputpre=input('你叫什么名字?')

  • C++控制台制作ATM机[通俗易懂]

    C++控制台制作ATM机[通俗易懂]文章目录题目代码实现所需要头文件Card类Bankcard类ATM类ATM类函数的声明主函数题目在控制台编程中共设置了三个类,ATM类、Card类和Bankcard类,设计函数实现登录、查询、修改密码、取款、存款、转账以及退出系统等功能。程序分别从MFC控件和c++控制台实现。同时在要求的基础之上,进行了部分仿ATM的优化,例如在登陆界面输入错误三次就会冻结账号退出系统,在MFC对话框中加入图…

  • 网络基础知识大全_网络基础知识入门到精通

    网络基础知识大全_网络基础知识入门到精通1)如何查看本机所开端口:用netstat-a—n命令查看!netstat结果显示有一些英文,简单说一下这些英文具体都代表什么:LISTEN:侦听来自远方的TCP端口的连接请求SYN-SENT:再

  • pycharm怎样编写java_Pycharm改进和编写代码[通俗易懂]

    pycharm怎样编写java_Pycharm改进和编写代码[通俗易懂]PyCharm包含用于编写代码的各种标准,其中包含适用于Python的适当缩进。这有助于提高代码标准并在PyCharm编辑器中编写完整的代码。改进代码完成PyCharm中的代码完成非常独特。您可以使用许多其他功能进一步增强它。请注意,编辑器提供了代码块的开始和结束。以下代码编写一个名为demo.py的文件中-message=’GIEWIVrGMTLIVrHIQS’#encrypte…

  • java 四舍五入保留小数点后两位

    java 四舍五入保留小数点后两位方式一:doublef=3.1516;BigDecimalb=newBigDecimal(f);doublef1=b.setScale(2,BigDecimal.ROUND_HALF_UP).doubleValue();输出结果f1为3.15;源码解读:  publicBigDecimalsetScale(intnewScale,introundingMode)//intnewScale为小数点后保留的位数,introundingMode为变量进

  • jboss安装与配置_下载qq和安装

    jboss安装与配置_下载qq和安装JBoss下载与JBoss安装一.              下载与安装JBoss在本文中,我们下载的JBoss版本为:4.2.1.GA。下载地址:http://www.jboss.org/jbossas/downloads/在如上的下载页中下载JBoss-4.2.1.GA.zip文件。下载完成后,将其解压缩后即可完成安装,解压缩后将其放置到

发表回复

您的电子邮箱地址不会被公开。

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