大家好,又见面了,我是你们的朋友全栈君。
mybatis返回Map结果集value为Null的情况下丢失key的解决办法
本博主之前一直是网络资源的索取者,本着开源精神愿意把自己在开发过程中遇到过的问题以及解决方案分享给大家,这是我的第一篇博客,希望以后能坚持写博客,让大家少走弯路、少踩坑。 废话少说,直入主题! springcloud微服务集成mybatis动态多数据源在网上有很多文章可以搜到,这里就不重复造轮子了。 如题,网上的很多解决方案比如: 尝试在application.yml 文件中配置 mybatis:callSettersOnNulls:true,对于springboot启动加载yml的单一数据源是有效的,但是在动态多数据源的情况下,是需要自己手动增加数据源配置类:DataSourceConfig.java,并且需要在启动类加上了@SpringBootApplication(exclude ={DataSourceAutoConfiguration.class})注解。 因此,上述解决方案就没用了,下面给出我的解决方案,亲测有效: 1.xml文件
代码语言:javascript复制<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文件
代码语言:javascript复制@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
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。