mybatis返回map类型数据空值字段不显示的解决方案

网友投稿 601 2022-08-22


mybatis返回map类型数据空值字段不显示的解决方案

目录mybatis返回map数据空值字段不显示查询sql添加每个字段的判断空ResultType利用实体返回springMVC+mybatis查询数据mybatis返回map空值未返回字段mybatis开启CallSettersOnNulls

mybatis返回map数据空值字段不显示

查询sql添加每个字段的判断空

IFNULL(rate,'') as rate

ResultType利用实体返回

不用map

springMVC+mybatis查询数据

返回resultType=”map”时,如果数据为空的字段,则该字段省略不显示,可以通过添加配置文件,规定查询数据为空是则返回null。

"http://mybatis.org/dtd/mybatis-3-config.dtd">

spring-mybatis.xml

如果想要配置rate的默认值,例如“”字符串,则可以建立一个类,实现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 { }}

在sql.xml文件定义与使用如下如下

mybatis返回map空值未返回字段

mybatis 开启CallSettersOnNulls

@Bean

public hdPKUYjsMfSqlSessionFactory sqlSessionFactoryBean() throws Exception

{

SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean();

sqlSessionFactoryBean.setDataSource(dataSource());

Configuration configuration = new .Configuration();

configuration.setCallSettersOnNulls(true);//map返回空字段消失问题

PageInterceptor pagePlugin = new PageInterceptor();

JalorResultSetInterceptor jalorResultSetPlugin = new JalorResultSetInterceptor();

ProgramInterceptor programPlugin = new ProgramInterceptor();

//添加插件

sqlSessionFactoryBean.setPlugins(new Interceptor[] {pagePlugin, jalorResultSetPlugin, programPlugin});

sqlSessionFactoryBean.setConfiguration(configuration);

return sqlSessionFactoryBean.getObject();

}


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:SpringBoot通过注解注入Bean的几种方式解析
下一篇:Java线程池7个参数的详细含义
相关文章

 发表评论

暂时没有评论,来抢沙发吧~