mybatis返回map类型数据空值字段不显示(三种解决方法)
来源:互联网 发布:中日农产品贸易数据 编辑:程序博客网 时间:2024/04/28 08:41
一、查询sql添加每个字段的判断空
IFNULL(rate,'') as rate
二、ResultType利用实体返回,不用map
三、springMVC+mybatis查询数据,返回resultType=”map”时,如果数据为空的字段,则该字段省略不显示,可以通过添加配置文件,规定查询数据为空是则返回null。
<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD SQL MAP Config 3.1//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd"><configuration> <settings> <setting name="callSettersOnNulls" value="true"/> </settings></configuration>
spring-mybatis.xml
<!-- spring和MyBatis完美整合,添加mybatis的配置映射文件 --> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource"/> <property name="configLocation" value="classpath:mybatis-configuration.xml"/> <!-- 自动扫描mapping.xml文件 --> <property name="mapperLocations" value="classpath:mapping/*.xml"></property> </bean>
如果想要配置rate的默认值,例如“”字符串,则可以建立一个类,实现Mybatis的TypeHandler接口
public class EmptyStringIfNull implements TypeHandler<String> { @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 { }}
在sql.xml文件定义与使用如下如下
<resultMap id="find" type="java.util.LinkedHashMap"> <result property="name" column="name" /> <result property="phone" column="phone" /> <result property="rate" column="rate" typeHandler="com.mybatis.EmptyStringIfNull"/></resultMap>
转自 http://blog.csdn.net/lulidaitian/article/details/70941769
阅读全文
0 0
- mybatis返回map类型数据空值字段不显示(三种解决方法)
- mybatis返回map类型数据空值字段不显示(三种解决方法)
- mybatis返回map类型数据空值字段不显示(三种解决方法)
- mybatis返回map类型数据空值字段不显示(三种解决方法)
- mybatis返回map类型数据空值字段不显示(三种解决方法)
- mybatis返回map类型数据空值字段不显示
- mybatis返回map类型数据空值字段不显示
- Mybatis字段值为空时,不返回map问题
- springMVC+mybatis查询数据,返回resultType=”map”时,如果数据为空的字段,则该字段省略不显示的解决方案
- 解决spring boot整合mybatis时 返回map value为空字段不显示
- Mybatis查询数据库空字段不返回
- mybatis 返回类型为HashMap 字段为空
- mybatis返回类型Map
- mybatis查询字段为空返回另一个字段的值
- dede 判断字段空值 不显示&显示别的字段
- 使用MyBatis查询int类型字段,返回NULL值时报异常的解决方法
- webservice Xfire 调用 返回值类型为map时,数据为空的问题
- mybatis查询如何返回List<Map>类型数据
- Stockbroker Grapevine (弗洛伊德算法)
- 关于h5的media元素总结
- HDU 1159 Common Subsequence
- 服务端UDP双向通信学习资料
- 日夜模式
- mybatis返回map类型数据空值字段不显示(三种解决方法)
- 【C++11】新特性——auto的使用
- SharedPreferences工具类
- 2017年8月7日提高组T1 呵呵
- 啥是Vue ???
- 堆优化的prim算法
- 如何快速的搭建Apache+MySQL+PHP+PERL的环境
- 剑指offer 之 字符串的全排列、全组合
- 【重装系统】Ubuntu系统重装为windows10