map key为null_mybatis json
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
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
相关文章
- 几个js实用代码——动态加载时间、滚动条优化、两个数组转化为map对象等
- Node.js 工具库 BlueBird 的一些例子:map,each 和 some
- golang中的map并发读写问题: Golang 协程并发使用 Map 的正确姿势
- Map集合总结
- 深入理解mybatis原理(五) MyBatis缓存机制的设计与实现
- map集合根据value找key(一个key或多个key)
- MyBatis——【第二章】mybatis动态sql(分页)
- MyBatis框架:第十章:mybatis缓存
- MyBatis框架:第十一章:mybatis 逆向工程
- MyBatis框架:第六章:mybatis的核心配置
- mybatis返回值为map类型时怎么处理_构造函数不能有返回类型
- mybatis 查询返回List集合、map集合、List<Map>集合[通俗易懂]
- MyBatis-Plus联表查询(Mybatis-Plus-Join)
- ORA-24195: attemp to retrieve the name list of a map message with size exceeding 1024 ORACLE 报错 故障修复 远程处理
- MySQL Error number: MY-010977; Symbol: ER_FAILED_TO_ADD_RESOURCE_GROUP_TO_MAP; SQLSTATE: HY000 报错 故障修复 远程处理
- Java基础学习笔记十七 集合框架(三)之Map详解编程语言
- Scalaz(30)- Free :Natural Tranformation ~> – map higher kinded types for free详解编程语言
- JavaBean和Map转换封装类详解编程语言
- C++ unordered_map删除元素(erase删除元素)详解
- map标题:使用Linux grep和nmap快速审计网络(linuxgrepn)
- 如何清空 Redis 中的 Map 数据?详细教程分享(redismap清空)
- 将Map存入Redis一步一步解决方案(将map存到redis中)
- 解决Redis频繁修改Map难题(redis频繁修改map)
- Oracle中Map结构的精妙运用(oracle中MAP结构)
- Redis批量获取多个Map(redis获取多个map)
- Redis解锁Map中蕴藏的绝技(redis获取map的值)
- java集合map取key使用示例java遍历map
- 用json方式实现在js中建立一个map