当前位置: 移动技术网 > IT编程>开发语言>Java > Mabatis错误提示Parameter index out of range的处理方法

Mabatis错误提示Parameter index out of range的处理方法

2019年07月19日  | 移动技术网IT编程  | 我要评论

75pk,齐齐哈尔天气预报15天查询,袁金华

这个问题把小编急毁了,捣腾了好几天还没有结果出来,今天终于捣腾出来了,下面小编把经过分享给大家,大家多多提出宝贵意见。

错误信息如下

08:34:43,302 debug getteachers:139 - ==> preparing: select a.*,b.classid,b.classname from teacherinfo a inner join classinfo b on a.teacherid=b.teacherid 
08:34:43,316 debug newpooledconnection:430 - com.mchange.v2.c3p0.impl.newpooledconnection@2f187f handling a throwable.
java.sql.sqlexception: parameter index out of range (1 > number of parameters, which is 0).
 at com.mysql.jdbc.sqlerror.createsqlexception(sqlerror.java:959)
 at com.mysql.jdbc.sqlerror.createsqlexception(sqlerror.java:898)
 at com.mysql.jdbc.sqlerror.createsqlexception(sqlerror.java:887)
 at com.mysql.jdbc.sqlerror.createsqlexception(sqlerror.java:862)
 at com.mysql.jdbc.preparedstatement.checkbounds(preparedstatement.java:3319)
 at com.mysql.jdbc.preparedstatement.setinternal(preparedstatement.java:3304)
 at com.mysql.jdbc.preparedstatement.setinternal(preparedstatement.java:3341)
 at com.mysql.jdbc.preparedstatement.setnull(preparedstatement.java:3380)
 at com.mchange.v2.c3p0.impl.newproxypreparedstatement.setnull(newproxypreparedstatement.java:157)
 at sun.reflect.nativemethodaccessorimpl.invoke0(native method)
 at sun.reflect.nativemethodaccessorimpl.invoke(unknown source)
 at sun.reflect.delegatingmethodaccessorimpl.invoke(unknown source)
 at java.lang.reflect.method.invoke(unknown source)
 at org.apache.ibatis.logging.jdbc.preparedstatementlogger.invoke(preparedstatementlogger.java:70)
 at com.sun.proxy.$proxy34.setnull(unknown source)
 at org.apache.ibatis.type.basetypehandler.setparameter(basetypehandler.java:43)
 at org.apache.ibatis.scripting.defaults.defaultparameterhandler.setparameters(defaultparameterhandler.java:81)
 at org.apache.ibatis.executor.statement.preparedstatementhandler.parameterize(preparedstatementhandler.java:80)
 at org.apache.ibatis.executor.statement.routingstatementhandler.parameterize(routingstatementhandler.java:61)
 at org.apache.ibatis.executor.simpleexecutor.preparestatement(simpleexecutor.java:74)
 at org.apache.ibatis.executor.simpleexecutor.doquery(simpleexecutor.java:59)
 at org.apache.ibatis.executor.baseexecutor.queryfromdatabase(baseexecutor.java:267)
 at org.apache.ibatis.executor.baseexecutor.query(baseexecutor.java:137)
 at org.apache.ibatis.executor.cachingexecutor.query(cachingexecutor.java:96)
 at org.apache.ibatis.executor.cachingexecutor.query(cachingexecutor.java:77)
 at org.apache.ibatis.session.defaults.defaultsqlsession.selectlist(defaultsqlsession.java:108)
 at org.apache.ibatis.session.defaults.defaultsqlsession.selectlist(defaultsqlsession.java:102)
 at sun.reflect.nativemethodaccessorimpl.invoke0(native method)
 at sun.reflect.nativemethodaccessorimpl.invoke(unknown source)
 at sun.reflect.delegatingmethodaccessorimpl.invoke(unknown source)
 at java.lang.reflect.method.invoke(unknown source)
 at org.mybatis.spring.sqlsessiontemplate$sqlsessioninterceptor.invoke(sqlsessiontemplate.java:434)
 at com.sun.proxy.$proxy15.selectlist(unknown source)
 at org.mybatis.spring.sqlsessiontemplate.selectlist(sqlsessiontemplate.java:231)
 at org.apache.ibatis.binding.mappermethod.executeformany(mappermethod.java:119)
 at org.apache.ibatis.binding.mappermethod.execute(mappermethod.java:63)
 at org.apache.ibatis.binding.mapperproxy.invoke(mapperproxy.java:52)
 at com.sun.proxy.$proxy20.getteachers(unknown source)
 at com.taohan.online.exam.service.impl.teacherinfoserviceimpl.getteachers(teacherinfoserviceimpl.java:59)
 at com.taohan.online.exam.handler.classinfohandler.preupdateclass(classinfohandler.java:176)
 at sun.reflect.nativemethodaccessorimpl.invoke0(native method)
 at sun.reflect.nativemethodaccessorimpl.invoke(unknown source)
 at sun.reflect.delegatingmethodaccessorimpl.invoke(unknown source)
 at java.lang.reflect.method.invoke(unknown source)
 at org.springframework.web.method.support.invocablehandlermethod.doinvoke(invocablehandlermethod.java:222)
 at org.springframework.web.method.support.invocablehandlermethod.invokeforrequest(invocablehandlermethod.java:137)
 at org.springframework.web.servlet.mvc.method.annotation.servletinvocablehandlermethod.invokeandhandle(servletinvocablehandlermethod.java:110)
 at org.springframework.web.servlet.mvc.method.annotation.requestmappinghandleradapter.invokehandlermethod(requestmappinghandleradapter.java:814)
 at org.springframework.web.servlet.mvc.method.annotation.requestmappinghandleradapter.handleinternal(requestmappinghandleradapter.java:737)
 at org.springframework.web.servlet.mvc.method.abstracthandlermethodadapter.handle(abstracthandlermethodadapter.java:85)
 at org.springframework.web.servlet.dispatcherservlet.dodispatch(dispatcherservlet.java:959)
 at org.springframework.web.servlet.dispatcherservlet.doservice(dispatcherservlet.java:893)
 at org.springframework.web.servlet.frameworkservlet.processrequest(frameworkservlet.java:969)
 at org.springframework.web.servlet.frameworkservlet.doget(frameworkservlet.java:860)
 at javax.servlet.http.httpservlet.service(httpservlet.java:617)
 at org.springframework.web.servlet.frameworkservlet.service(frameworkservlet.java:845)
 at javax.servlet.http.httpservlet.service(httpservlet.java:717)
 at org.apache.catalina.core.applicationfilterchain.internaldofilter(applicationfilterchain.java:290)
 at org.apache.catalina.core.applicationfilterchain.dofilter(applicationfilterchain.java:206)
 at org.springframework.web.filter.hiddenhttpmethodfilter.dofilterinternal(hiddenhttpmethodfilter.java:77)
 at org.springframework.web.filter.onceperrequestfilter.dofilter(onceperrequestfilter.java:107)
 at org.apache.catalina.core.applicationfilterchain.internaldofilter(applicationfilterchain.java:235)
 at org.apache.catalina.core.applicationfilterchain.dofilter(applicationfilterchain.java:206)
 at org.springframework.web.filter.characterencodingfilter.dofilterinternal(characterencodingfilter.java:121)
 at org.springframework.web.filter.onceperrequestfilter.dofilter(onceperrequestfilter.java:107)
 at org.apache.catalina.core.applicationfilterchain.internaldofilter(applicationfilterchain.java:235)
 at org.apache.catalina.core.applicationfilterchain.dofilter(applicationfilterchain.java:206)
 at org.apache.catalina.core.standardwrappervalve.invoke(standardwrappervalve.java:233)
 at org.apache.catalina.core.standardcontextvalve.invoke(standardcontextvalve.java:191)
 at org.apache.catalina.core.standardhostvalve.invoke(standardhostvalve.java:127)
 at org.apache.catalina.valves.errorreportvalve.invoke(errorreportvalve.java:102)
 at org.apache.catalina.core.standardenginevalve.invoke(standardenginevalve.java:109)
 at org.apache.catalina.connector.coyoteadapter.service(coyoteadapter.java:298)
 at org.apache.coyote.http11.http11processor.process(http11processor.java:857)
 at org.apache.coyote.http11.http11protocol$http11connectionhandler.process(http11protocol.java:588)
 at org.apache.tomcat.util.net.jioendpoint$worker.run(jioendpoint.java:489)
 at java.lang.thread.run(unknown source)
08:34:43,319 debug sqlutils:85 - attempted to convert sqlexception to sqlexception. leaving it alone. [sqlstate: s1009; errorcode: 0]
java.sql.sqlexception: parameter index out of range (1 > number of parameters, which is 0).
 at com.mysql.jdbc.sqlerror.createsqlexception(sqlerror.java:959)
 at com.mysql.jdbc.sqlerror.createsqlexception(sqlerror.java:898)
 at com.mysql.jdbc.sqlerror.createsqlexception(sqlerror.java:887)
 at com.mysql.jdbc.sqlerror.createsqlexception(sqlerror.java:862)
 at com.mysql.jdbc.preparedstatement.checkbounds(preparedstatement.java:3319)
 at com.mysql.jdbc.preparedstatement.setinternal(preparedstatement.java:3304)
 at com.mysql.jdbc.preparedstatement.setinternal(preparedstatement.java:3341)
 at com.mysql.jdbc.preparedstatement.setnull(preparedstatement.java:3380)
 at com.mchange.v2.c3p0.impl.newproxypreparedstatement.setnull(newproxypreparedstatement.java:157)
 at sun.reflect.nativemethodaccessorimpl.invoke0(native method)
 at sun.reflect.nativemethodaccessorimpl.invoke(unknown source)
 at sun.reflect.delegatingmethodaccessorimpl.invoke(unknown source)
 at java.lang.reflect.method.invoke(unknown source)
 at org.apache.ibatis.logging.jdbc.preparedstatementlogger.invoke(preparedstatementlogger.java:70)
 at com.sun.proxy.$proxy34.setnull(unknown source)
 at org.apache.ibatis.type.basetypehandler.setparameter(basetypehandler.java:43)
 at org.apache.ibatis.scripting.defaults.defaultparameterhandler.setparameters(defaultparameterhandler.java:81)
 at org.apache.ibatis.executor.statement.preparedstatementhandler.parameterize(preparedstatementhandler.java:80)
 at org.apache.ibatis.executor.statement.routingstatementhandler.parameterize(routingstatementhandler.java:61)
 at org.apache.ibatis.executor.simpleexecutor.preparestatement(simpleexecutor.java:74)
 at org.apache.ibatis.executor.simpleexecutor.doquery(simpleexecutor.java:59)
 at org.apache.ibatis.executor.baseexecutor.queryfromdatabase(baseexecutor.java:267)
 at org.apache.ibatis.executor.baseexecutor.query(baseexecutor.java:137)
 at org.apache.ibatis.executor.cachingexecutor.query(cachingexecutor.java:96)
 at org.apache.ibatis.executor.cachingexecutor.query(cachingexecutor.java:77)
 at org.apache.ibatis.session.defaults.defaultsqlsession.selectlist(defaultsqlsession.java:108)
 at org.apache.ibatis.session.defaults.defaultsqlsession.selectlist(defaultsqlsession.java:102)
 at sun.reflect.nativemethodaccessorimpl.invoke0(native method)
 at sun.reflect.nativemethodaccessorimpl.invoke(unknown source)
 at sun.reflect.delegatingmethodaccessorimpl.invoke(unknown source)
 at java.lang.reflect.method.invoke(unknown source)
 at org.mybatis.spring.sqlsessiontemplate$sqlsessioninterceptor.invoke(sqlsessiontemplate.java:434)
 at com.sun.proxy.$proxy15.selectlist(unknown source)
 at org.mybatis.spring.sqlsessiontemplate.selectlist(sqlsessiontemplate.java:231)
 at org.apache.ibatis.binding.mappermethod.executeformany(mappermethod.java:119)
 at org.apache.ibatis.binding.mappermethod.execute(mappermethod.java:63)
 at org.apache.ibatis.binding.mapperproxy.invoke(mapperproxy.java:52)
 at com.sun.proxy.$proxy20.getteachers(unknown source)
 at com.taohan.online.exam.service.impl.teacherinfoserviceimpl.getteachers(teacherinfoserviceimpl.java:59)
 at com.taohan.online.exam.handler.classinfohandler.preupdateclass(classinfohandler.java:176)
 at sun.reflect.nativemethodaccessorimpl.invoke0(native method)
 at sun.reflect.nativemethodaccessorimpl.invoke(unknown source)
 at sun.reflect.delegatingmethodaccessorimpl.invoke(unknown source)
 at java.lang.reflect.method.invoke(unknown source)
 at org.springframework.web.method.support.invocablehandlermethod.doinvoke(invocablehandlermethod.java:222)
 at org.springframework.web.method.support.invocablehandlermethod.invokeforrequest(invocablehandlermethod.java:137)
 at org.springframework.web.servlet.mvc.method.annotation.servletinvocablehandlermethod.invokeandhandle(servletinvocablehandlermethod.java:110)
 at org.springframework.web.servlet.mvc.method.annotation.requestmappinghandleradapter.invokehandlermethod(requestmappinghandleradapter.java:814)
 at org.springframework.web.servlet.mvc.method.annotation.requestmappinghandleradapter.handleinternal(requestmappinghandleradapter.java:737)
 at org.springframework.web.servlet.mvc.method.abstracthandlermethodadapter.handle(abstracthandlermethodadapter.java:85)
 at org.springframework.web.servlet.dispatcherservlet.dodispatch(dispatcherservlet.java:959)
 at org.springframework.web.servlet.dispatcherservlet.doservice(dispatcherservlet.java:893)
 at org.springframework.web.servlet.frameworkservlet.processrequest(frameworkservlet.java:969)
 at org.springframework.web.servlet.frameworkservlet.doget(frameworkservlet.java:860)
 at javax.servlet.http.httpservlet.service(httpservlet.java:617)
 at org.springframework.web.servlet.frameworkservlet.service(frameworkservlet.java:845)
 at javax.servlet.http.httpservlet.service(httpservlet.java:717)
 at org.apache.catalina.core.applicationfilterchain.internaldofilter(applicationfilterchain.java:290)
 at org.apache.catalina.core.applicationfilterchain.dofilter(applicationfilterchain.java:206)
 at org.springframework.web.filter.hiddenhttpmethodfilter.dofilterinternal(hiddenhttpmethodfilter.java:77)
 at org.springframework.web.filter.onceperrequestfilter.dofilter(onceperrequestfilter.java:107)
 at org.apache.catalina.core.applicationfilterchain.internaldofilter(applicationfilterchain.java:235)
 at org.apache.catalina.core.applicationfilterchain.dofilter(applicationfilterchain.java:206)
 at org.springframework.web.filter.characterencodingfilter.dofilterinternal(characterencodingfilter.java:121)
 at org.springframework.web.filter.onceperrequestfilter.dofilter(onceperrequestfilter.java:107)
 at org.apache.catalina.core.applicationfilterchain.internaldofilter(applicationfilterchain.java:235)
 at org.apache.catalina.core.applicationfilterchain.dofilter(applicationfilterchain.java:206)
 at org.apache.catalina.core.standardwrappervalve.invoke(standardwrappervalve.java:233)
 at org.apache.catalina.core.standardcontextvalve.invoke(standardcontextvalve.java:191)
 at org.apache.catalina.core.standardhostvalve.invoke(standardhostvalve.java:127)
 at org.apache.catalina.valves.errorreportvalve.invoke(errorreportvalve.java:102)
 at org.apache.catalina.core.standardenginevalve.invoke(standardenginevalve.java:109)
 at org.apache.catalina.connector.coyoteadapter.service(coyoteadapter.java:298)
 at org.apache.coyote.http11.http11processor.process(http11processor.java:857)
 at org.apache.coyote.http11.http11protocol$http11connectionhandler.process(http11protocol.java:588)
 at org.apache.tomcat.util.net.jioendpoint$worker.run(jioendpoint.java:489)
 at java.lang.thread.run(unknown source)
08:34:43,320 debug defaultconnectiontester:126 - testing a connection in response to an exception:
java.sql.sqlexception: parameter index out of range (1 > number of parameters, which is 0).
 at com.mysql.jdbc.sqlerror.createsqlexception(sqlerror.java:959)
 at com.mysql.jdbc.sqlerror.createsqlexception(sqlerror.java:898)
 at com.mysql.jdbc.sqlerror.createsqlexception(sqlerror.java:887)
 at com.mysql.jdbc.sqlerror.createsqlexception(sqlerror.java:862)
 at com.mysql.jdbc.preparedstatement.checkbounds(preparedstatement.java:3319)
 at com.mysql.jdbc.preparedstatement.setinternal(preparedstatement.java:3304)
 at com.mysql.jdbc.preparedstatement.setinternal(preparedstatement.java:3341)
 at com.mysql.jdbc.preparedstatement.setnull(preparedstatement.java:3380)
 at com.mchange.v2.c3p0.impl.newproxypreparedstatement.setnull(newproxypreparedstatement.java:157)
 at sun.reflect.nativemethodaccessorimpl.invoke0(native method)
 at sun.reflect.nativemethodaccessorimpl.invoke(unknown source)
 at sun.reflect.delegatingmethodaccessorimpl.invoke(unknown source)
 at java.lang.reflect.method.invoke(unknown source)
 at org.apache.ibatis.logging.jdbc.preparedstatementlogger.invoke(preparedstatementlogger.java:70)
 at com.sun.proxy.$proxy34.setnull(unknown source)
 at org.apache.ibatis.type.basetypehandler.setparameter(basetypehandler.java:43)
 at org.apache.ibatis.scripting.defaults.defaultparameterhandler.setparameters(defaultparameterhandler.java:81)
 at org.apache.ibatis.executor.statement.preparedstatementhandler.parameterize(preparedstatementhandler.java:80)
 at org.apache.ibatis.executor.statement.routingstatementhandler.parameterize(routingstatementhandler.java:61)
 at org.apache.ibatis.executor.simpleexecutor.preparestatement(simpleexecutor.java:74)
 at org.apache.ibatis.executor.simpleexecutor.doquery(simpleexecutor.java:59)
 at org.apache.ibatis.executor.baseexecutor.queryfromdatabase(baseexecutor.java:267)
 at org.apache.ibatis.executor.baseexecutor.query(baseexecutor.java:137)
 at org.apache.ibatis.executor.cachingexecutor.query(cachingexecutor.java:96)
 at org.apache.ibatis.executor.cachingexecutor.query(cachingexecutor.java:77)
 at org.apache.ibatis.session.defaults.defaultsqlsession.selectlist(defaultsqlsession.java:108)
 at org.apache.ibatis.session.defaults.defaultsqlsession.selectlist(defaultsqlsession.java:102)
 at sun.reflect.nativemethodaccessorimpl.invoke0(native method)
 at sun.reflect.nativemethodaccessorimpl.invoke(unknown source)
 at sun.reflect.delegatingmethodaccessorimpl.invoke(unknown source)
 at java.lang.reflect.method.invoke(unknown source)
 at org.mybatis.spring.sqlsessiontemplate$sqlsessioninterceptor.invoke(sqlsessiontemplate.java:434)
 at com.sun.proxy.$proxy15.selectlist(unknown source)
 at org.mybatis.spring.sqlsessiontemplate.selectlist(sqlsessiontemplate.java:231)
 at org.apache.ibatis.binding.mappermethod.executeformany(mappermethod.java:119)
 at org.apache.ibatis.binding.mappermethod.execute(mappermethod.java:63)
 at org.apache.ibatis.binding.mapperproxy.invoke(mapperproxy.java:52)
 at com.sun.proxy.$proxy20.getteachers(unknown source)
 at com.taohan.online.exam.service.impl.teacherinfoserviceimpl.getteachers(teacherinfoserviceimpl.java:59)
 at com.taohan.online.exam.handler.classinfohandler.preupdateclass(classinfohandler.java:176)
 at sun.reflect.nativemethodaccessorimpl.invoke0(native method)
 at sun.reflect.nativemethodaccessorimpl.invoke(unknown source)
 at sun.reflect.delegatingmethodaccessorimpl.invoke(unknown source)
 at java.lang.reflect.method.invoke(unknown source)
 at org.springframework.web.method.support.invocablehandlermethod.doinvoke(invocablehandlermethod.java:222)
 at org.springframework.web.method.support.invocablehandlermethod.invokeforrequest(invocablehandlermethod.java:137)
 at org.springframework.web.servlet.mvc.method.annotation.servletinvocablehandlermethod.invokeandhandle(servletinvocablehandlermethod.java:110)
 at org.springframework.web.servlet.mvc.method.annotation.requestmappinghandleradapter.invokehandlermethod(requestmappinghandleradapter.java:814)
 at org.springframework.web.servlet.mvc.method.annotation.requestmappinghandleradapter.handleinternal(requestmappinghandleradapter.java:737)
 at org.springframework.web.servlet.mvc.method.abstracthandlermethodadapter.handle(abstracthandlermethodadapter.java:85)
 at org.springframework.web.servlet.dispatcherservlet.dodispatch(dispatcherservlet.java:959)
 at org.springframework.web.servlet.dispatcherservlet.doservice(dispatcherservlet.java:893)
 at org.springframework.web.servlet.frameworkservlet.processrequest(frameworkservlet.java:969)
 at org.springframework.web.servlet.frameworkservlet.doget(frameworkservlet.java:860)
 at javax.servlet.http.httpservlet.service(httpservlet.java:617)
 at org.springframework.web.servlet.frameworkservlet.service(frameworkservlet.java:845)
 at javax.servlet.http.httpservlet.service(httpservlet.java:717)
 at org.apache.catalina.core.applicationfilterchain.internaldofilter(applicationfilterchain.java:290)
 at org.apache.catalina.core.applicationfilterchain.dofilter(applicationfilterchain.java:206)
 at org.springframework.web.filter.hiddenhttpmethodfilter.dofilterinternal(hiddenhttpmethodfilter.java:77)
 at org.springframework.web.filter.onceperrequestfilter.dofilter(onceperrequestfilter.java:107)
 at org.apache.catalina.core.applicationfilterchain.internaldofilter(applicationfilterchain.java:235)
 at org.apache.catalina.core.applicationfilterchain.dofilter(applicationfilterchain.java:206)
 at org.springframework.web.filter.characterencodingfilter.dofilterinternal(characterencodingfilter.java:121)
 at org.springframework.web.filter.onceperrequestfilter.dofilter(onceperrequestfilter.java:107)
 at org.apache.catalina.core.applicationfilterchain.internaldofilter(applicationfilterchain.java:235)
 at org.apache.catalina.core.applicationfilterchain.dofilter(applicationfilterchain.java:206)
 at org.apache.catalina.core.standardwrappervalve.invoke(standardwrappervalve.java:233)
 at org.apache.catalina.core.standardcontextvalve.invoke(standardcontextvalve.java:191)
 at org.apache.catalina.core.standardhostvalve.invoke(standardhostvalve.java:127)
 at org.apache.catalina.valves.errorreportvalve.invoke(errorreportvalve.java:102)
 at org.apache.catalina.core.standardenginevalve.invoke(standardenginevalve.java:109)
 at org.apache.catalina.connector.coyoteadapter.service(coyoteadapter.java:298)
 at org.apache.coyote.http11.http11processor.process(http11processor.java:857)
 at org.apache.coyote.http11.http11protocol$http11connectionhandler.process(http11protocol.java:588)
 at org.apache.tomcat.util.net.jioendpoint$worker.run(jioendpoint.java:489)
 at java.lang.thread.run(unknown source)

错误信息关键描述

parameter index out of range (1 > number of parameters, which is 0)

  反正就是说我的参数存在问题

业务代码描述

  修改班级信息时可以修改班级对应班主任,所以需要查询出对应的非班主任教师。

  handler

@requestmapping(value="edit/class/{classid}", method=requestmethod.get)
 public modelandview preupdateclass(@pathvariable("classid") integer classid) {
  logger.info("预修改班级处理");
  modelandview model = new modelandview();
  //获取要修改班级
  classinfo classinfo = classinfoservice.getclassbyid(classid);
  model.setviewname("/admin/classedit");
  model.addobject("editclass", classinfo);
  list<gradeinfo> grades = gradeinfoservice.getgrades();
  //获取不是班主任的教师
  teacher.setiswork(0); // iswork为0就不是班主任
  list<teacherinfo> teachers = teacherinfoservice.getteachers(null); //通过下面配置文件可知,该方法需要传入一个 map 集合,而我这里传入一个 null
  //如果没有可用班主任
  if (teachers.size() == 0 || teachers == null) {
   teacher.setteacherid(classinfo.getteacher().getteacherid());
   teacher.setteachername("暂无剩余教师");
   teachers.add(teacher);
  }
  model.addobject("teachers", teachers);
  model.addobject("grades", grades);
  return model;
 }

  映射文件

    statement会接收一个 map 集合

<resultmap type="com.taohan.online.exam.po.teacherinfo" id="getteacherresultmap">
  <id column="teacherid" property="teacherid"/>
  <result column="teachername" property="teachername" />
  <result column="teacheraccount" property="teacheraccount"/>
  <result column="teacherpwd" property="teacherpwd"/>
  <result column="adminpower" property="adminpower"/>
  <result column="iswork" property="iswork"/>
  <association property="classinfo" javatype="com.taohan.online.exam.po.classinfo">
   <id column="classid" property="classid"/>
   <result column="classname" property="classname"/>
  </association>
 </resultmap>
 <parametermap type="java.util.map" id="getteachersparametermap">
  <!-- 教师对象 -->
  <parameter property="teacher" resultmap="getteacherresultmap"/>
  <!-- 起始位置索引 -->
  <parameter property="startindex" resultmap="getteacherresultmap"/>
  <!-- 每页显示数据量 -->
  <parameter property="pageshow" resultmap="getteacherresultmap"/>
 </parametermap>
 <!-- 使用 paramentermap 查询 -->
 <select id="getteachers" parametermap="getteachersparametermap" resultmap="getteacherresultmap">
  select a.*,b.classid,b.classname from teacherinfo a
  inner join classinfo b on a.teacherid=b.teacherid
     <!-- 
      getteachers()方法我传入的是 null,那么,在下面进行条件判断的时候并不能找到 teacher、startindex、pageshow,所以抛出异常
      -->
  <where>
   <if test="teacher != null">
    iswork=#{teacher.iswork}
   </if>
  </where>
  <if test="startindex != null and pageshow != null">
   limit #{startindex}, #{pageshow}
  </if>
 </select>

总结

  通过之前犯过类似的错误,以及这次错误,我发现 今后只要是 parameter index out of range (1 > number of parameters, which is 0) 类似的错误大致定位在 映射文件和调用方法传入参数,

  映射文件

    如果使用了 parametermap, resultmap,或是返回集合,就要检查参数名称和属性名称是否一致

  调用方法

    针对使用了 parametermap 或 parametertype,需要检查传入map中的键是否存在、匹配,或传入对象是否存在指定属性

下面看下在数据库中遇到parameter index out of range  错误该如何处理?

最近学ssm框架的时候,遇到了这个错误,找了半天的原因,最后发现原来是sql语句中多了一对单引号。传入值的类型为string类型,就以为还要加引号以表示传入的是字符串,其实是错的,还是初学对其还不太了解。

如下:

错误的:

<update id="updatestate" parametertype="java.lang.string">
   update login set state = 0 where lid = '#{value}'
</update>

正确的:

<update id="updatestate" parametertype="java.lang.string">
   update login set state = 0 where lid = #{value}
</update>

以上所述是小编给大家介绍的mabatis错误提示parameter index out of range的处理方法,希望对大家有所帮助

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网