您的位置:首页 > 大数据 > 人工智能

MyBatis批量操作报错:Parameter 'xxxList' not found. Available parameters are [list]

2015-04-06 22:46 495 查看
需求: 根据传入的参数批量 删除数据:

DAO:

List ll = new ArrayList<Integer>();
		for(int i=10;i<25;i++){
			ll.add(i);
		}
	  
		int res = userMapper.delUser(li);
		System.out.println(res);


xml:

<delete id="delUser" parameterType="list" >
		delete  from users where id in 
		<foreach collection="li" index="index" open="(" close=")" separator="," item="itm">
			#{itm}
		</foreach>
	</delete>


这样处理会报错

com.chenzhou.base.mybatis.IbatisSystemException: SqlSession operation; nested exception is org.apache.ibatis.exceptions.PersistenceException: 
### Error querying database.  Cause: org.apache.ibatis.binding.BindingException: Parameter 'li' not found. Available parameters are [list]
### Cause: org.apache.ibatis.binding.BindingException: Parameter 'studentNameList' not found. Available parameters are [list]
	at com.chenzhou.base.mybatis.SqlSessionTemplate.wrapException(SqlSessionTemplate.java:341)
	at com.chenzhou.base.mybatis.SqlSessionTemplate.execute(SqlSessionTemplate.java:127)
	at com.chenzhou.base.mybatis.SqlSessionTemplate.execute(SqlSessionTemplate.java:106)
	at com.chenzhou.base.mybatis.SqlSessionTemplate.selectOne(SqlSessionTemplate.java:138)
	at com.chenzhou.dao.GenericMybatisDao.count(GenericMybatisDao.java:306)
	at com.chenzhou.cds.ps.dao.impl.StudentDao.getStudentCount(StudentDao.java:42)
	at com.chenzhou.cds.ps.dao.impl.StudentDao$$FastClassByCGLIB$$8819e766.invoke(<generated>)
	at net.sf.cglib.proxy.MethodProxy.invoke(MethodProxy.java:191)
	at org.springframework.aop.framework.Cglib2AopProxy$CglibMethodInvocation.invokeJoinpoint(Cglib2AopProxy.java:689)
	at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:150)
	at org.springframework.aop.aspectj.MethodInvocationProceedingJoinPoint.proceed(MethodInvocationProceedingJoinPoint.java:80)
	at com.chenzhou.util.LogUtil.doMethodInfo(LogUtil.java:85)
	at com.chenzhou.util.LogUtil.doDebugMethodLog(LogUtil.java:36)
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
	at java.lang.reflect.Method.invoke(Method.java:597)
	at org.springframework.aop.aspectj.AbstractAspectJAdvice.invokeAdviceMethodWithGivenArgs(AbstractAspectJAdvice.java:621)
	at org.springframework.aop.aspectj.AbstractAspectJAdvice.invokeAdviceMethod(AbstractAspectJAdvice.java:610)
	at org.springframework.aop.aspectj.AspectJAroundAdvice.invoke(AspectJAroundAdvice.java:65)
	at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172)
	at org.springframework.aop.aspectj.AspectJAfterThrowingAdvice.invoke(AspectJAfterThrowingAdvice.java:55)
	at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172)
	at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:110)
	at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172)
	at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:90)
	at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172)
	at org.springframework.aop.framework.Cglib2AopProxy$DynamicAdvisedInterceptor.intercept(Cglib2AopProxy.java:622)
	at com.chenzhou.cds.ps.dao.impl.StudentDao$$EnhancerByCGLIB$$d4fcf513.getStudentCount(<generated>)
	at com.chenzhou.ps.dao.StudentDaoTest.testgetStudentCount(StudentDaoTest.java:44)
……


根据报错日志分析,是MyBatis在解析xml时找不到其中声明的li,但是在Dao中明明传的参数就是li,怎么会报错呢?

查询了一下MyBatis官方的说明文档,终于找到了原因,在http://mybatis.github.io/mybatis-3/zh/dynamic-sql.html#foreach里有一段说明:

写道

注意 你可以传递一个 List 实例或者数组作为参数对象传给 MyBatis。当你这么做的时 候,MyBatis 会自动将它包装在一个 Map 中,用名称在作为键。List 实例将会以“list” 作为键,而数组实例将会以“array”作为键。

因为我传的参数只有一个,而且传入的是一个List集合,所以mybatis会自动封装成Map<"list",li>。在解析的时候会通过“list”作为Map的key值去寻找。但是我在xml中却声明成li了,所以自然会报错找不到。
更改:
<delete id="delUser" parameterType="map" >
		delete  from users where id in 
		<foreach collection="li" index="index" open="(" close=")" separator="," item="itm">
			#{itm}
		</foreach>
	</delete>


List ll = new ArrayList<Integer>();
		for(int i=10;i<25;i++){
			ll.add(i);
		}
	    HashMap li =new HashMap();
	    li.put("li", ll);
		int res = userMapper.delUser(li);
		System.out.println(res);


修改dao中的参数传入方式,手动封装成map,然后把map当参数传进去,这样mybatis会跟据参数map的key去匹配value,由于dao的key和xml中的key一样可以匹配上,所以OK,如果
HashMap li =new HashMap();
	    li.put("li", ll);


和xml中

<foreach collection="li"  ........
不一样仍然会报错。

另一种修改的方式是直接修改成

<foreach collection="list"
xml中的接受的参数仍然是list即可。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐