2012-07-02 3 views
0

나 최대 절전 모드를 사용하여 내 데이터베이스 테이블을 업데이트하려고하지만 난이 일을하려고 할 때 다음과 같은 오류가 무엇입니까 :최대 절전 모드 : 잘못된 매개 변수 인덱스

10:46:01,034 DEBUG LongType:80 - binding '19991' to parameter: 57 
10:46:01,034 INFO LongType:91 - could not bind value '19991' to parameter: 57; Invalid parameter index 57. 
10:46:01,049 WARN JDBCExceptionReporter:71 - SQL Error: 0, SQLState: 07009 
10:46:01,049 ERROR JDBCExceptionReporter:72 - Invalid parameter index 57. 
10:46:01,049 ERROR AbstractFlushingEventListener:301 - Could not synchronize database state with session 

19991를 삽입하려고하고있는이 값은 이미를 내가 그것을 이미 값을 덮어 쓸 때문에 데이터베이스에이이 내가 데이터베이스 열

로 문서를 맵핑하고 어떻게 전체 오류

org.hibernate.exception.SQLGrammarException: could not update: [com.project.class.dataobject.PSDBusinessAssociate#18962] 
at org.hibernate.exception.SQLStateConverter.convert(SQLStateConverter.java:67) 
at org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:43) 
at org.hibernate.persister.entity.AbstractEntityPersister.update(AbstractEntityPersister.java:2360) 
at org.hibernate.persister.entity.AbstractEntityPersister.updateOrInsert(AbstractEntityPersister.java:2242) 
at org.hibernate.persister.entity.AbstractEntityPersister.update(AbstractEntityPersister.java:2542) 
at org.hibernate.action.EntityUpdateAction.execute(EntityUpdateAction.java:92) 
at org.hibernate.engine.ActionQueue.execute(ActionQueue.java:248) 
at org.hibernate.engine.ActionQueue.executeActions(ActionQueue.java:232) 
at org.hibernate.engine.ActionQueue.executeActions(ActionQueue.java:140) 
at org.hibernate.event.def.AbstractFlushingEventListener.performExecutions(AbstractFlushingEventListener.java:298) 
at org.hibernate.event.def.DefaultFlushEventListener.onFlush(DefaultFlushEventListener.java:27) 
at org.hibernate.impl.SessionImpl.flush(SessionImpl.java:1000) 
at org.hibernate.impl.SessionImpl.managedFlush(SessionImpl.java:338) 
at org.hibernate.transaction.JDBCTransaction.commit(JDBCTransaction.java:106) 
at org.springframework.orm.hibernate3.HibernateTransactionManager.doCommit(HibernateTransactionManager.java:655) 
at org.springframework.transaction.support.AbstractPlatformTransactionManager.processCommit(AbstractPlatformTransactionManager.java:709) 
at org.springframework.transaction.support.AbstractPlatformTransactionManager.commit(AbstractPlatformTransactionManager.java:678) 
at org.springframework.transaction.interceptor.TransactionAspectSupport.commitTransactionAfterReturning(TransactionAspectSupport.java:321) 
at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:116) 
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:171) 
at org.springframework.aop.framework.Cglib2AopProxy$DynamicAdvisedInterceptor.intercept(Cglib2AopProxy.java:635) 
at com.project.class.service.dwr.BusinessAssociateFormService$$EnhancerByCGLIB$$ff37dc8d.updateBusinessAssociate(<generated>) 
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.directwebremoting.impl.DefaultRemoter$1.doFilter(DefaultRemoter.java:740) 
at org.directwebremoting.impl.DefaultRemoter.execute(DefaultRemoter.java:744) 
at org.directwebremoting.impl.DefaultRemoter.execute(DefaultRemoter.java:593) 
at org.directwebremoting.dwrp.BaseCallHandler.handle(BaseCallHandler.java:90) 
at org.directwebremoting.servlet.UrlProcessor.handle(UrlProcessor.java:120) 
at org.directwebremoting.servlet.DwrServlet.doPost(DwrServlet.java:141) 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:641) 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:722) 
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290) 
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) 
at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:265) 
at org.acegisecurity.intercept.web.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:107) 
at org.acegisecurity.intercept.web.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:72) 
at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:275) 
at org.acegisecurity.ui.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:124) 
at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:275) 
at org.acegisecurity.ui.AbstractProcessingFilter.doFilter(AbstractProcessingFilter.java:271) 
at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:275) 
at org.acegisecurity.context.HttpSessionContextIntegrationFilter.doFilter(HttpSessionContextIntegrationFilter.java:249) 
at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:275) 
at org.acegisecurity.util.FilterChainProxy.doFilter(FilterChainProxy.java:149) 
at org.acegisecurity.util.FilterToBeanProxy.doFilter(FilterToBeanProxy.java:98) 
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:228) 
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175) 
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128) 
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:105) 
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109) 
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:212) 
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:818) 
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:624) 
at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:445) 
at java.lang.Thread.run(Thread.java:619) 
Caused by: java.sql.SQLException: Invalid parameter index 57. 
at net.sourceforge.jtds.jdbc.JtdsPreparedStatement.getParameter(JtdsPreparedStatement.java:255) 
at net.sourceforge.jtds.jdbc.JtdsPreparedStatement.setParameter(JtdsPreparedStatement.java:326) 
at net.sourceforge.jtds.jdbc.JtdsPreparedStatement.setLong(JtdsPreparedStatement.java:509) 
at com.mchange.v2.c3p0.impl.NewProxyPreparedStatement.setLong(NewProxyPreparedStatement.java:703) 
at org.hibernate.type.LongType.set(LongType.java:42) 
at org.hibernate.type.NullableType.nullSafeSet(NullableType.java:83) 
at org.hibernate.type.NullableType.nullSafeSet(NullableType.java:60) 
at org.hibernate.type.ManyToOneType.nullSafeSet(ManyToOneType.java:78) 
at org.hibernate.persister.entity.AbstractEntityPersister.dehydrate(AbstractEntityPersister.java:1932) 
at org.hibernate.persister.entity.AbstractEntityPersister.update(AbstractEntityPersister.java:2306) 
... 57 more 

입니다

테이블과 열의 이름도 모두 정확하므로 잘못된 정보가 표시되지 않습니다. 더 많은 코드를 추가 할 필요가있는 경우, 물어와 내가 추가 할 것입니다 그것을

편집

쿼리

update BusinessAssociate set version=?, modifiedBy=?, address1=?, streetTypeId=?, address2=?, address3=?, city=?, stateCode=?, state=?, postCode=?, countryId=?, provinceId=?, islandId=?, percentOwnership=?, comment=?, companyId=?, businessTitleId=?, firstName=?, surname=?, primaryAssociate=?, nationality=?, socialSecurityNumber=?, associateId=?, middleName=?, jobTitle=?, gender=?, previousNames=?, priorAddress1=?, priorStreetTypeId=?, priorAddress2=?, priorAddress3=?, priorCity=?, priorStateCode=?, priorState=?, priorPostCode=?, priorCountryId=?, priorProvinceId=?, priorIslandId=?, workPhoneCountryCode=?, workPhoneCityCode=?, workPhone=?, homePhoneCountryCode=?, homePhoneCityCode=?, homePhone=?, mobilePhoneCountryCode=?, mobilePhoneOperatorCode=?, mobilePhone=?, dateOfBirth=?, cityOfBirth=?, countryOfBirthId=?, proofOfResidentialAddressId=?, addressIdentificationTypeId=?, criminalCheckId=?, fitAndProperQuestionnaireId=? where businessAssociateId=? and version=? 
+0

검색어에 57 개의 매개 변수가 있습니까? 감사합니다 – esmoreno

+0

그냥 거기에 그들을 계산하고 업데이트 진술은 54 매개 변수가 ... 나는 질문에 업데이 트 문을 추가했지만 55 아니 57에 오류를 당겨하지 않을까요? – flexinIT

+1

쿼리에 56 개의 매개 변수가 있고 57 위치에 값을 설정하고 있습니다. 이것이 문제입니다. 값 '19991'을 매개 변수 : 57에 바인드 할 수 없습니다. – esmoreno

답변

0

음, 분명히 뭔가 잘못이고 당신은 너무 많은 코드를 우리가 할 수있는 추가 나타납니다 시도하고 도와주세요.
또한, hibernate.cfg.xml의 show_sql 매개 변수를 true로 설정 했습니까?
이것은 당신을 도울 수 있고 최대 절전 모드가 생성하는 질의를 볼 수 있습니다. 그러나 당신은 무슨 일이 일어나고 있는지 볼 수 있습니다. (아마도 계산할 것입니다)
당신이 잘못된 번호를 가지고있을 때 매개 변수 - 확인해야 할 사항입니다.
또한 "org.hibernate"아래의 모든 코드를 디버그하여 로그하도록 애플리케이션의 log4j 설정을 변경할 수 있습니다.
더 나은 로깅을 사용하면 문제를 이해할 수있을 것이며 문제가 아니라면 더 많은 코드를 공개해야 도움이 될 것입니다.

+0

그래, 내가 모든 SQL을 볼 수 있도록 최대 절전 모드가 생성되는 모든 SQL을 볼 수 있도록 내 log4j 파일을 편집했습니다 진술과 나는 이미 그들을 통과하고 그들은 모두 괜찮아요 (잘 하나 또는 두 개의 잘못된 장소에 있으며, 위의 54가 필요할 때만 57을 반환합니다)하지만 실제 SQL 코드 자체는 모두 괜찮습니다. 모든 정확한 세부 정보 – flexinIT