ibatis传入list对象

在使用ibatis的时候经常需要传入list对象,sql语句如下。

<select id="GET-PERSONS" parameterClass="java.util.ArrayList" resultClass="pojo.Person">
	<![CDATA[
			select * from  person where id in
	]]>
	<iterate  open="(" close=")" conjunction=",">  
			#list[]#
	</iterate>
</select>
这个是简单的sql语句,对于list中是别的对象的,比如List<Person>这个参数传进来时需要这样使用

<select id="GET-PERSONS" parameterClass="java.util.List" resultClass="pojo.Person">
	<![CDATA[
			select * from  person where id in
	]]>
	<iterate open="(" close=")" conjunction=",">  
		<![CDATA[ 
			#list[].id#
		]]>
	</iterate>
</select>


注意:上面select语句入参用的是parameterClass是java.util.ArrayList类,而不是一个map,这时iterator语句就不需要有property="ids"属性,

<select id="GET-PERSONSS" parameterClass="java.util.ArrayList" resultClass="pojo.Person">
	<![CDATA[
			select * from  person where id in
	]]>
	<iterate property="ids" open="(" close=")" conjunction=",">  
			#ids[]#
	</iterate>
</select>

如果有这个属性的话ibatis会从参数中去找属性为ids这个对象,而参数是一个list没有这个属性,因此就会报

Caused by: com.ibatis.common.jdbc.exception.NestedSQLException:
--- The error occurred in person-sqlmap.xml.
--- The error occurred while preparing the mapped statement for execution.
--- Check the person.GET-PERSONS.
--- Check the parameter map.
--- Cause: com.ibatis.common.beans.ProbeException: Error getting ordinal list fr
om JavaBean. Cause java.lang.StringIndexOutOfBoundsException: String index out o
f range: -1

这个错误。


如果parameter使用map,那么需要在java代码中将这个list封装进map。



转自http://www.myexception.cn/program/675170.html

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值