Im using OpenJPA 2.2.0 + enhancement with Apache TomEE
2013/3/11 José Luis Cetina <maxtorz...@gmail.com> > Im using OpenJPA 2.2.0 9 enhancement with Apache TomEE > > > 2013/3/11 José Luis Cetina <maxtorz...@gmail.com> > >> Here it is: >> >> WARNING - Unexpected exception from beforeCompletion; transaction will >> roll back >> <openjpa-2.2.0-r422266:1244990 nonfatal user error> >> org.apache.openjpa.persistence.InvalidStateException: Primary key field >> com.grupokx.model.core.MyClass.idTest of >> com.grupokx.model.core.MyClass@198e0705 has non-default value. The >> instance life cycle is in PNewState state and hence an existing non-default >> value for the identity field is not permitted. You either need to remove >> the @GeneratedValue annotation or modify the code to remove the initializer >> processing. >> at >> org.apache.openjpa.util.ApplicationIds.assign(ApplicationIds.java:489) >> at org.apache.openjpa.util.ApplicationIds.assign(ApplicationIds.java:469) >> at >> org.apache.openjpa.jdbc.kernel.JDBCStoreManager.assignObjectId(JDBCStoreManager.java:740) >> at >> org.apache.openjpa.kernel.DelegatingStoreManager.assignObjectId(DelegatingStoreManager.java:135) >> at >> org.apache.openjpa.kernel.StateManagerImpl.assignObjectId(StateManagerImpl.java:612) >> at >> org.apache.openjpa.kernel.StateManagerImpl.preFlush(StateManagerImpl.java:2977) >> at org.apache.openjpa.kernel.PNewState.beforeFlush(PNewState.java:40) >> at >> org.apache.openjpa.kernel.StateManagerImpl.beforeFlush(StateManagerImpl.java:1054) >> at org.apache.openjpa.kernel.BrokerImpl.flush(BrokerImpl.java:2112) >> at org.apache.openjpa.kernel.BrokerImpl.flushSafe(BrokerImpl.java:2072) >> at >> org.apache.openjpa.kernel.BrokerImpl.beforeCompletion(BrokerImpl.java:1990) >> at >> org.apache.geronimo.transaction.manager.TransactionImpl.beforeCompletion(TransactionImpl.java:527) >> at >> org.apache.geronimo.transaction.manager.TransactionImpl.beforeCompletion(TransactionImpl.java:512) >> at >> org.apache.geronimo.transaction.manager.TransactionImpl.beforePrepare(TransactionImpl.java:413) >> at >> org.apache.geronimo.transaction.manager.TransactionImpl.commit(TransactionImpl.java:262) >> at >> org.apache.geronimo.transaction.manager.TransactionManagerImpl.commit(TransactionManagerImpl.java:252) >> at >> org.apache.openejb.core.CoreUserTransaction.commit(CoreUserTransaction.java:57) >> at >> org.apache.openejb.core.transaction.EjbUserTransaction.commit(EjbUserTransaction.java:37) >> at >> org.apache.openejb.core.BaseContext$UserTransactionWrapper.commit(BaseContext.java:247) >> at >> com.grupokx.businesslayer.ejbs.examenesdiagnostico.ExamenesAplicadosFacade.editarBDTest(ExamenesAplicadosFacade.java:277) >> at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) >> at >> sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) >> at >> sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) >> at java.lang.reflect.Method.invoke(Method.java:601) >> at >> org.apache.openejb.core.interceptor.ReflectionInvocationContext$Invocation.invoke(ReflectionInvocationContext.java:181) >> at >> org.apache.openejb.core.interceptor.ReflectionInvocationContext.proceed(ReflectionInvocationContext.java:163) >> at org.apache.openejb.cdi.CdiInterceptor.invoke(CdiInterceptor.java:130) >> at >> org.apache.openejb.cdi.CdiInterceptor.access$000(CdiInterceptor.java:43) >> at org.apache.openejb.cdi.CdiInterceptor$1.call(CdiInterceptor.java:67) >> at >> org.apache.openejb.cdi.CdiInterceptor.aroundInvoke(CdiInterceptor.java:73) >> at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) >> at >> sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) >> at >> sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) >> at java.lang.reflect.Method.invoke(Method.java:601) >> at >> org.apache.openejb.core.interceptor.ReflectionInvocationContext$Invocation.invoke(ReflectionInvocationContext.java:181) >> at >> org.apache.openejb.core.interceptor.ReflectionInvocationContext.proceed(ReflectionInvocationContext.java:163) >> at >> org.apache.openejb.monitoring.StatsInterceptor.record(StatsInterceptor.java:180) >> at >> org.apache.openejb.monitoring.StatsInterceptor.invoke(StatsInterceptor.java:99) >> at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) >> at >> sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) >> at >> sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) >> at java.lang.reflect.Method.invoke(Method.java:601) >> at >> org.apache.openejb.core.interceptor.ReflectionInvocationContext$Invocation.invoke(ReflectionInvocationContext.java:181) >> at >> org.apache.openejb.core.interceptor.ReflectionInvocationContext.proceed(ReflectionInvocationContext.java:163) >> at >> org.apache.openejb.core.interceptor.InterceptorStack.invoke(InterceptorStack.java:138) >> at >> org.apache.openejb.core.stateless.StatelessContainer._invoke(StatelessContainer.java:233) >> at >> org.apache.openejb.core.stateless.StatelessContainer.invoke(StatelessContainer.java:185) >> at >> org.apache.openejb.core.ivm.EjbObjectProxyHandler.synchronizedBusinessMethod(EjbObjectProxyHandler.java:256) >> at >> org.apache.openejb.core.ivm.EjbObjectProxyHandler.businessMethod(EjbObjectProxyHandler.java:251) >> at >> org.apache.openejb.core.ivm.EjbObjectProxyHandler._invoke(EjbObjectProxyHandler.java:85) >> at >> org.apache.openejb.core.ivm.BaseEjbProxyHandler.invoke(BaseEjbProxyHandler.java:279) >> at $Proxy219.editarBDTest(Unknown Source) >> at >> com.grupokx.examenesdiagnostico.controller.examenes.ExamenesIndexMBean.onCellEdit(ExamenesIndexMBean.java:146) >> at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) >> at >> sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) >> at >> sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) >> at java.lang.reflect.Method.invoke(Method.java:601) >> at >> org.apache.webbeans.intercept.InterceptorHandler.invoke(InterceptorHandler.java:322) >> at >> org.apache.webbeans.intercept.NormalScopedBeanInterceptorHandler.invoke(NormalScopedBeanInterceptorHandler.java:117) >> at >> org.apache.webbeans.intercept.NormalScopedBeanInterceptorHandler.invoke(NormalScopedBeanInterceptorHandler.java:108) >> at >> com.grupokx.examenesdiagnostico.controller.examenes.ExamenesIndexMBean_$$_javassist_52.onCellEdit(ExamenesIndexMBean_$$_javassist_52.java) >> at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) >> at >> sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) >> at >> sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) >> at java.lang.reflect.Method.invoke(Method.java:601) >> at org.apache.el.parser.AstValue.invoke(AstValue.java:278) >> at >> org.apache.el.MethodExpressionImpl.invoke(MethodExpressionImpl.java:274) >> at >> org.apache.myfaces.view.facelets.el.ContextAwareTagMethodExpression.invoke(ContextAwareTagMethodExpression.java:96) >> at >> org.primefaces.component.behavior.ajax.AjaxBehaviorListenerImpl.processArgListener(AjaxBehaviorListenerImpl.java:56) >> at >> org.primefaces.component.behavior.ajax.AjaxBehaviorListenerImpl.processAjaxBehavior(AjaxBehaviorListenerImpl.java:47) >> at >> org.primefaces.event.CellEditEvent.processListener(CellEditEvent.java:55) >> at >> javax.faces.component.behavior.BehaviorBase.broadcast(BehaviorBase.java:74) >> at >> javax.faces.component.UIComponentBase.broadcast(UIComponentBase.java:407) >> at javax.faces.component.UIData.broadcast(UIData.java:1610) >> at javax.faces.component.UIData.broadcast(UIData.java:1596) >> at javax.faces.component.UIViewRoot._broadcastAll(UIViewRoot.java:1028) >> at javax.faces.component.UIViewRoot.broadcastEvents(UIViewRoot.java:286) >> at javax.faces.component.UIViewRoot._process(UIViewRoot.java:1375) >> at >> javax.faces.component.UIViewRoot.processApplication(UIViewRoot.java:752) >> at >> org.apache.myfaces.lifecycle.InvokeApplicationExecutor.execute(InvokeApplicationExecutor.java:38) >> at >> org.apache.myfaces.lifecycle.LifecycleImpl.executePhase(LifecycleImpl.java:170) >> at >> org.apache.myfaces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:117) >> at >> org.apache.myfaces.extensions.cdi.jsf2.impl.listener.phase.CodiLifecycleWrapper.execute(CodiLifecycleWrapper.java:95) >> at javax.faces.webapp.FacesServlet.service(FacesServlet.java:197) >> at >> org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305) >> at >> org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) >> at >> org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:222) >> at >> org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:123) >> at org.apache.tomee.catalina.OpenEJBValve.invoke(OpenEJBValve.java:45) >> at >> org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:581) >> at >> org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:171) >> at >> org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:99) >> at >> org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118) >> at >> org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407) >> at >> org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1004) >> at >> org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:589) >> at >> org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:312) >> at >> java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110) >> at >> java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603) >> at java.lang.Thread.run(Thread.java:722) >> >> >> 2013/3/11 Rick Curtis <curti...@gmail.com> >> >>> Can you please post the entire stack trace? >>> >>> >>> On Mon, Mar 11, 2013 at 2:23 PM, José Luis Cetina <maxtorz...@gmail.com >>> >wrote: >>> >>> > Hi, i have problems trying to use merge method. >>> > >>> > I have this scenerio. >>> > >>> > 1. My Managedbean get a list of Object (MyClass) those objects are in >>> the >>> > database, the ejb use a Criteria to get all records. >>> > >>> > 2. The managedbean change some property (like description) in one of >>> the >>> > detached entities (that i get from the list). >>> > >>> > 3. The managedbean call a EJB and in the EJB i try to use merge for >>> update >>> > propuses. Then i get this exception: >>> > org.apache.openjpa.persistence.InvalidStateException: Primary key >>> field >>> > com.test.MyClass.id of com.test.MyClass.id 652eb3bd has non-default >>> value. >>> > The instance life cycle is in PNewState state and hence an existing >>> > non-default value for the identity field is not permitted. You either >>> need >>> > to >>> > remove the @GeneratedValue annotation or modify the code to remove the >>> > initializer processing. >>> > >>> > I dont know why this error is happens, the id of the object is the >>> same id >>> > that i get when i do the query in the EJB, that id, never changes. >>> > >>> > Anyone has any idea, what im doing wrong?? >>> > >>> >>> >>> >>> -- >>> *Rick Curtis* >>> >> >> >> >> -- >> ------------------------------------------------------------------- >> *SCJA. José Luis Cetina* >> ------------------------------------------------------------------- >> > > > > -- > ------------------------------------------------------------------- > *SCJA. José Luis Cetina* > ------------------------------------------------------------------- > -- ------------------------------------------------------------------- *SCJA. José Luis Cetina* -------------------------------------------------------------------