博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
解决mybatis空字段null字段不返回
阅读量:4587 次
发布时间:2019-06-09

本文共 2661 字,大约阅读时间需要 8 分钟。

Mybatis在使用resultMap来映射查询结果中的列,如果查询结果中包含空值的列(不是null),则Mybatis在映射的时候,不会映射这个字段,例如 查询 name,sex,age,数据库中的age字段没有值,Mybatis返回的map中只映射了 name和sex字段,而age字段则没有包含。那么如何将age字段映射到map中呢。提供四种解决方法:方法一:      MyBatis 不知道你传入的 null 参数对应的 jdbc 类型是什么,因为在 MyBatis 看来,null 在数据库中可以为多种类型(例如,可以为 CHAR、VARCHAR、DATE 等),于是 MyBatis 就傻眼了,解决办法自然是你要告诉 MyBatis 这个 null 对应的 jdbc 类型是什么。于是得出的答案如下:              在你相应的 Mapper 中,传入该参数的地方写明 jdbc 类型即可,比如原来传参数是这样写的:#{myNullParameter},把它改成这样写即可:#{myNullParameter, jdbcType=VARCHAR}方法二:      使用Mybatis config配置      创建configuration.xml      
配置Mybatis的SqlSessionFactoryBean
在这种配置中,age将以null值映射到map中。方法三: 如果想要配置age的默认值,则可以建立一个类,实现Mybatis的TypeHandler接口 public class EmptyStringIfNull implements TypeHandler
{ @Override public String getResult(ResultSet rs, String columnName) throws SQLException { return (rs.getString(columnName) == null) ? "" : rs.getString(columnName); } @Override public String getResult(ResultSet rs, int columnIndex) throws SQLException { return (rs.getString(columnIndex) == null) ? "" : rs.getString(columnIndex); } @Override public String getResult(CallableStatement cs, int columnIndex) throws SQLException { return (cs.getString(columnIndex) == null) ? "" : cs.getString(columnIndex); } @Override public void setParameter(PreparedStatement ps, int arg1, String str, JdbcType jdbcType) throws SQLException { }} 继续在resultMap中使用,即可配置age的默认值(上述代码中age的默认值为"")
网上有些资料中提到可以使用 defaultValue 和 nullValue的配置,但是这中配置是ibatis的用法,在Mybatis中已经移除。 方法四:
  1. <!-- myBatis配置 -->  
  2. <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">  
  3.     <property name="dataSource" ref="dataSource" />  
  4.       
  5.     <!-- 表示在mybatis.mapping包或以下所有目录中,以 Mapper.xml结尾所有文件 -->  
  6.     <property name="mapperLocations">  
  7.         <value>classpath:com/cncounter/dao/oracle/**/*Mapper.xml</value>  
  8.         <!--   
  9.         <list>  
  10.             <value>classpath:com/cncounter/dao/oracle/res/*Mapper.xml</value>  
  11.             <value>classpath:com/cncounter/dao/oracle/user/*Mapper.xml</value>  
  12.         </list>  
  13.          -->  
  14.     </property>  
  15.     <!--   
  16.     <property name="configLocation">  
  17.         <value>classpath:mybatis/mybatis-env-setting.xml</value>  
  18.     </property>  
  19.      -->  
  20.     <!--  切换一种方式,不配置configLocation  -->  
  21.     <property name="configurationProperties">  
  22.         <props>  
  23.             <prop key="cacheEnabled">true</prop>  
  24.             <prop key="callSettersOnNulls">true</prop>  
  25.         </props>  
  26.     </property>  
  27. </bean>  
方法五: 对象属性自己初始化值

 

转载于:https://www.cnblogs.com/sprinng/p/6610310.html

你可能感兴趣的文章
简单实现Tabbar的隐藏显示动画 By H罗
查看>>
电脑自动开机设置教程
查看>>
rpc接口mock平台
查看>>
传感器模块
查看>>
《奇思妙想》人物篇--图灵奖得主概览
查看>>
Azure开发者任务之二:Cloud Service项目添加到ASP.Net Web中
查看>>
2017.2.28 activiti实战--第七章--Spring容器集成应用实例(五)普通表单
查看>>
读书笔记第一章
查看>>
Android 操作SQLite基本用法
查看>>
iis7 发布mvc3 遇到的HTTP错误 403.14-Forbidden Web 服务器被配置为不列出此目录的内容...
查看>>
(vue.js)element ui 表单验证 this$refs[formName]validate里面的内容死活不执行
查看>>
启动多个appium服务(同时运行多台设备)
查看>>
Java大数相乘-hdu1063
查看>>
mysql-mmm 部署高可用集群
查看>>
solaris启动过程详解 分类: arm-linux-Ubuntu ...
查看>>
while循环和递归
查看>>
Linux下yum安装Redis
查看>>
.Net 下未捕获异常的处理
查看>>
[机器学习]-Adaboost提升算法从原理到实践
查看>>
AOP概念
查看>>