ibatis中动态查询返回字段返回用resultClass="java.util.HashMap" 的问题

本文介绍了解决MyBatis在使用动态SQL时遇到的列名冲突问题,特别是当查询条件变化导致列名不一致时如何通过设置remapResults=true来避免BadSqlGrammarException错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

org.springframework.jdbc.BadSqlGrammarException: SqlMapClient operation; bad SQL grammar []; nested exception is com.ibatis.common.jdbc.exception.NestedSQLException:  
--- The error occurred in jndi:/localhost/studen/WEB-INF/app-config/query/sqlmap/Test.xml. 
--- The error occurred while applying a result map. 
--- Check the QueryReport_QueryBucketTest.SELECT_QUERYUBUCKETTESTDETAIL_CN-AutoResultMap. 
--- Check the result mapping for the 'LPV_CNT_1' property. 
--- Cause: java.sql.SQLException: 列名无效

 

 

    <select id="SELECT_QUERYUBUCKETTESTDETAIL_CN" resultClass="java.util.HashMap" parameterClass="java.util.HashMap" 
       select yyyymmdd,
       <isNotEmpty prepend=" " property="user_type">
             <isEqual property="user_type" compareValue="1">
                cookie_cnt as  cookie_cnt_1
             </isEqual>
              <isEqual property="user_type" compareValue="2">
                cookie_cnt as  cookie_cnt_2
             </isEqual>
              <isEqual property="user_type" compareValue="3">
                cookie_cnt as  cookie_cnt_3
             </isEqual>
      </isNotEmpty>

 

当user_type=1查询的时候列名是cookie_cnt_1, 如果第一次查询user_type=1,那么第二次查询user_type=2就会报这个错,因为ibatis保留列名为第一次查询时候的列名cookie_cnt_1,ibatis可以设置一个参数remapResults="true",每次查询都重新更新列名,

 

<select id="SELECT_QUERYUBUCKETTESTDETAIL_CN" resultClass="java.util.HashMap" parameterClass="java.util.HashMap"  remapResults="true"

 

#spring: # jpa: # hibernate: # ddl-auto: none # ★★记得上线时改回来 # show-sql: false # database-platform: org.hibernate.dialect.Oracle10gDialect # open-in-view: false # datasource: # url: jdbc:oracle:thin:@192.168.88.26:1521:orcl # driver-class-name: oracle.jdbc.OracleDriver # username: dba_mgr # password: totodir #hikari数据库连接池 # hikari: # pool-name: Retail_HikariCP # minimum-idle: 5 #最小空闲连接数量 # idle-timeout: 300000 #空闲连接存活最大时间,默认600000(10分钟) # maximum-pool-size: 10 #连接池最大连接数,默认是10 # auto-commit: true #此属性控制从池返回的连接的默认自动提交行为,默认值:true # max-lifetime: 600000 #此属性控制池中连接的最长生命周期,值0表示无限生命周期,默认1800000即30分钟 # connection-timeout: 30000 #数据库连接超时时间,默认30秒,即30000 # connection-test-query: select 1 from dual #server: # servlet: # session: # timeout: 300m # port: 7086 # undertow: # url-charset: UTF-8 #logging: # file: # path: /hyerpinterfacelog # name: hyerpinterface.log server: port: 7086 servlet: session: timeout: 1800s spring: #jpa: # show-sql: true # properties: # hibernate: # format_sql: true datasource: dynamic: primary: oracle strict: false datasource: syoracle: url: jdbc:oracle:thin:@192.168.88.26:1521:orcl username: dba_mgr password: totodir driver-class-name: oracle.jdbc.OracleDriver druid: initial-size: 10 min-idle: 10 max-active: 500 max-wait: 60000 time-between-eviction-runs-millis: 60000 min-evictable-idle-time-millis: 300000 lyoracle: url: jdbc:oracle:thin:@192.168.88.30:1521:orcl username: dba_mgr password: totodir driver-class-name: oracle.jdbc.OracleDriver druid: initial-size: 10 min-idle: 10 max-active: 500 max-wait: 60000 time-between-eviction-runs-millis: 60000 min-evictable-idle-time-millis: 300000 mybatis-plus: global-config: db-config: # 主键ID类型 # id-type: none logic-delete-field: deleted logic-delete-value: 1 logic-not-delete-value: 0 configuration: # 驼峰下划线转换 map-underscore-to-camel-case: true # 这个配置会将执行的sql打印出来,在开发或测试的时候可以用 log-impl: org.apache.ibatis.logging.stdout.StdOutImpl import com.alibaba.druid.pool.DruidDataSource; import com.hyerp.hyerpinterface.config.DynamicDataSource; import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Primary; import javax.sql.DataSource; import java.util.HashMap; import java.util.Map; @Configuration public class DataSourceConfig { // 沈阳数据源 (0101) @Bean("syOracleDataSource") @ConfigurationProperties(prefix = "spring.datasource.syoracle") public DataSource syOracleDataSource() { return new DruidDataSource(); // 使用Druid连接池 } // 洛阳数据源 (0102) @Bean("lyOracleDataSource") @ConfigurationProperties(prefix = "spring.datasource.lyoracle") public DataSource lyOracleDataSource() { return new DruidDataSource(); // 使用Druid连接池 } // 主数据源(动态路由) @Primary @Bean("dynamicDataSource") public DataSource dynamicDataSource() { Map<Object, Object> targetDataSources = new HashMap<>(2); // 使用部门编码作为数据源标识 targetDataSources.put("-5716907732163998808", syOracleDataSource()); // 沈阳连接 targetDataSources.put("4294613579574035536", syOracleDataSource()); // 沈阳传感 targetDataSources.put("0103", lyOracleDataSource()); // 洛阳 // 默认使用沈阳数据源 return new DynamicDataSource(syOracleDataSource(), targetDataSources); } }package com.hyerp.hyerpinterface.dao; import com.baomidou.dynamic.datasource.annotation.DS; import com.hyerp.hyerpinterface.domain.entity.OaItemAbove; import org.springframework.data.jpa.repository.JpaRepository; import org.springframework.data.jpa.repository.Modifying; import org.springframework.data.jpa.repository.Query; import org.springframework.data.repository.query.Param; import javax.transaction.Transactional; import java.util.List; import java.util.Optional; /** * @Author GGZ * @Date 2023/3/20 14:06 * @Version 1.5 */ public interface OaitemRepo extends JpaRepository<OaItemAbove, String> { List<OaItemAbove> findByIdnum(String Idnum); List<OaItemAbove> findByShowvalueAndRef(String showvalue, String refid); List<OaItemAbove> findByShowvalue(String showvalue); @Transactional @DS("syoracle") @Query(value = "SELECT SHOWVALUE FROM OACTP_ENUM_ITEM WHERE IDNUM = ?", nativeQuery = true) Optional<OaItemAbove> selectidnumop(@Param("idnum") String idnum); @Transactional @DS("syoracle") @Query(value = "SELECT SHOWVALUE FROM OACTP_ENUM_ITEM WHERE IDNUM = 8347348803478963605", nativeQuery = true) } } 该sql语句在数据库能查到SELECT SHOWVALUE FROM OACTP_ENUM_ITEM WHERE IDNUM = 8347348803478963605在程序中查询是空怎么解决
最新发布
06-12
import org.apache.ibatis.io.Resources; import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory; import org.apache.ibatis.session.SqlSessionFactoryBuilder; import org.junit.Test; import org.mybatis.mapper.UserMapper; import org.mybatis.pojo.User; import java.awt.print.Book; import java.io.File; import java.io.IOException; import java.io.InputStream; import java.util.List; public class MyBatisTest { @Test public void testMyBatis() throws IOException { //加载核心配置文件 InputStream is = Resources.getResourceAsStream("mybatis-config.xml"); //获取sqlSessionFactoryBuilder SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder(); //获取sqlSessionFactory对象,是生产sqlSession的一个工厂 SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(is); //获取sqlSession对象,代表java程序与数据库之间的对话,HttpSession是Java程序与浏览器间的对话 SqlSession sqlSession = sqlSessionFactory.openSession(true);//默认不自动提交 //获取mapper接口对象 UserMapper mapper=sqlSession.getMapper(UserMapper.class); //测试功能 // 提交事务,打开autoCommit就不用手动提交了 // sqlSession.commit(); // int result=mapper.insertUser();//返回一个受影响的行数,增删改查返回值都是返回行数 // int result=mapper.updateUser(); // User user=mapper.selectUser(); // int result=mapper.deleteUser(); // System.out.println(user); // System.out.println(result); } }如何查找所有对象,形成list集合
03-15
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值