ibatis报列名无效的一个异常分析

Caused by: org.springframework.jdbc.UncategorizedSQLException: SqlMapClient operation; uncategorized SQLException for SQL []; SQL state [null]; error code [0]; 列名无效; nested exception is java.sql.SQLException: 列名无效
	at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:83)
	at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:80)
	at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:80)
	at org.springframework.orm.ibatis.SqlMapClientTemplate.execute(SqlMapClientTemplate.java:212)
	at org.springframework.orm.ibatis.SqlMapClientTemplate.executeWithListResult(SqlMapClientTemplate.java:249)
	at com.asc.alibaba.orm.ibatis.SqlMapClientTemplate.queryForList(SqlMapClientTemplate.java:65)
	at com.asc.alibaba.orm.ibatis.SqlMapClientTemplate.queryForList(SqlMapClientTemplate.java:47)
	at com.asc.alibaba.orm.ibatis.AbstractDaoRouter.query(AbstractDaoRouter.java:66)
	at com.asc.alibaba.orm.ibatis.AbstractDaoRouter.query(AbstractDaoRouter.java:175)
	at com.alibaba.click.service.app.impl.AppServiceImpl.getUserApps(AppServiceImpl.java:52)
	at com.alibaba.click.web.module.screen.app.AppList.execute(AppList.java:38)
	at com.alibaba.click.web.module.screen.app.AppList$$FastClassByCGLIB$$be3cb533.invoke(<generated>)
	at net.sf.cglib.reflect.FastMethod.invoke(FastMethod.java:53)
	at com.alibaba.citrus.service.moduleloader.impl.adapter.MethodInvoker.invoke(MethodInvoker.java:72)
	at com.alibaba.citrus.service.moduleloader.impl.adapter.DataBindingAdapter.execute(DataBindingAdapter.java:37)
	at com.alibaba.citrus.turbine.pipeline.valve.PerformScreenValve.performScreenModule(PerformScreenValve.java:100)
	... 48 more
Caused by: java.sql.SQLException: 列名无效
	at com.asc.alibaba.dao.ibatis.sqlmap.engine.impl.SqlMapExecutorDelegate.queryForList(SqlMapExecutorDelegate.java:234)
	at com.asc.alibaba.dao.ibatis.sqlmap.engine.impl.SqlMapSessionImpl.queryForList(SqlMapSessionImpl.java:42)
	at com.asc.alibaba.orm.ibatis.SqlMapClientTemplate$2.doInSqlMapClient(SqlMapClientTemplate.java:70)
	at org.springframework.orm.ibatis.SqlMapClientTemplate.execute(SqlMapClientTemplate.java:209)

ibatis的配置:

  <resultMap id="App_ResultMap" class="com.alibaba.click.bean.App" >
    <result column="ID" property="id" jdbcType="INTEGER" />
    <result column="APPNAME" property="appname" jdbcType="VARCHAR" />
    <result column="USER_ID" property="userId" jdbcType="INTEGER" />
    <result column="STATUS" property="status" jdbcType="CHAR" />
    <result column="OWNER" property="owner" jdbcType="VARCHAR" />
    <result column="SYNC_TYPE" property="syncType" jdbcType="VARCHAR" />
    <result column="CREATE_TIME" property="createTime" />
    <result column="MODIFY_TIME" property="modifyTime" />
    <result column="LAST_SYNC_TIME" property="lastSyncTime" />
    <result column="USERNAME" property="userName" jdbcType="VARCHAR" />
    <result column="DW_CLICK_URL" property="dwClickUrl"  jdbcType="VARCHAR"/>
    <result column="DW_EXPOSURE_URL" property="dwExposureUrl" jdbcType="VARCHAR" />
  </resultMap>
  
  <!-- 查询 -->
  <select id="query" resultMap="App_ResultMap" parameterClass="java.util.Map" >
    select CK_APP.ID, CK_APP.APPNAME, CK_APP.USER_ID, CK_APP.STATUS, CK_APP.OWNER,
    	   CK_APP.CREATE_TIME, CK_APP.MODIFY_TIME, CK_APP.LAST_SYNC_TIME,
    	   wpf_user.USERNAME,CK_APP.DW_CLICK_URL,CK_APP.DW_EXPOSURE_URL
    from 
    	CK_APP, wpf_user
    where
    	<!--  wpf_user.USER_ID=#userId# AND -->
    	CK_APP.STATUS != '0' AND
    	CK_APP.USER_ID = wpf_user.USER_ID <!-- AND
    	CK_APP.ID in
    	<iterate open="(" close=")" conjunction="," property="appIdList">  
            #appIdList[]#
        </iterate>  -->
  </select>

这里query的select语句查询出来的少了一个resultmap的一个字段 <result column="SYNC_TYPE" property="syncType" jdbcType="VARCHAR" />,所以报列名无效,

 

在下面的两个类里面会对查询结果根据resultmap反射到对应的bean里进行处理,可以查看对应的源码进行深入了解:

 


 



posted @ 2012-06-01 10:50  zhwj184  阅读(535)  评论(0编辑  收藏  举报