spring boot app jpa在一个控制器中工作而不是在另一个控制器

时间:2017-08-23 09:30:02

标签: java spring hibernate jpa

  

异常:提交事务时出错;嵌套异常是javax.persistence.RollbackException:提交事务时出错   2017-08-19 16:51:28,120 WARN c.a.v.c.VerificationController Stack Trace:org.springframework.orm.jpa.JpaSystemException:提交事务时出错;嵌套异常是javax.persistence.RollbackException:提交事务时出错       在org.springframework.orm.jpa.EntityManagerFactoryUtils.convertJpaAccessExceptionIfPossible(EntityManagerFactoryUtils.java:403)       在org.springframework.orm.jpa.vendor.HibernateJpaDialect.translateExceptionIfPossible(HibernateJpaDialect.java:226)       at org.springframework.orm.jpa.ExtendedEntityManagerCreator $ ExtendedEntityManagerSynchronization.convertException(ExtendedEntityManagerCreator.java:492)       在org.springframework.orm.jpa.ExtendedEntityManagerCreator $ ExtendedEntityManagerSynchronization.afterCommit(ExtendedEntityManagerCreator.java:465)       at org.springframework.transaction.support.TransactionSynchronizationUtils.invokeAfterCommit(TransactionSynchronizationUtils.java:134)       at org.springframework.transaction.support.TransactionSynchronizationUtils.triggerAfterCommit(TransactionSynchronizationUtils.java:122)       在org.springframework.transaction.support.AbstractPlatformTransactionManager.triggerAfterCommit(AbstractPlatformTransactionManager.java:944)       at org.springframework.transaction.support.AbstractPlatformTransactionManager.processCommit(AbstractPlatformTransactionManager.java:781)       在org.springframework.transaction.support.AbstractPlatformTransactionManager.commit(AbstractPlatformTransactionManager.java:710)       at org.springframework.transaction.interceptor.TransactionAspectSupport.commitTransactionAfterReturning(TransactionAspectSupport.java:512)       at org.springframework.transaction.interceptor.TransactionAspectSupport.invokeWithinTransaction(TransactionAspectSupport.java:298)       at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:96)       在org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:182)       at org.springframework.dao.support.PersistenceExceptionTranslationInterceptor.invoke(PersistenceExceptionTranslationInterceptor.java:136)       在org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:182)       at org.springframework.data.jpa.repository.support.CrudMethodMetadataPostProcessor $ CrudMethodMetadataPopulatingMethodInterceptor.invoke(CrudMethodMetadataPostProcessor.java:134)       在org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:182)       在org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:92)       在org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:182)       在org.springframework.data.repository.core.support.SurroundingTransactionDetectorMethodInterceptor.invoke(SurroundingTransactionDetectorMethodInterceptor.java:58)       在org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:182)       在org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:212)       在com.sun.proxy。$ Proxy1019.save(未知来源)       在com.aadhaar.verify.controller.VerificationController.Verification(VerificationController.java:296)       at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)       at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)       at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)       at java.lang.reflect.Method.invoke(Method.java:498)       在org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:208)       在org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:135)       在org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:100)       在org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:859)       在org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:769)       在org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:86)       在org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:970)       在org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:904)       在org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:971)       在org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:874)       在javax.servlet.http.HttpServlet.service(HttpServlet.java:707)       在org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:848)       在javax.servlet.http.HttpServlet.service(HttpServlet.java:790)       在weblogic.servlet.internal.StubSecurityHelper $ ServletServiceAction.run(StubSecurityHelper.java:286)       在weblogic.servlet.internal.StubSecurityHelper $ ServletServiceAction.run(StubSecurityHelper.java:260)       在weblogic.servlet.internal.StubSecurityHelper.invokeServlet(StubSecurityHelper.java:137)       在weblogic.servlet.internal.ServletStubImpl.execute(ServletStubImpl.java:350)       在weblogic.servlet.internal.TailFilter.doFilter(TailFilter.java:25)       在weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:78)       在org.springframework.security.web.FilterChainProxy $ VirtualFilterChain.doFilter(FilterChainProxy.java:317)       在org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:127)       在org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:91)       在org.springframework.security.web.FilterChainProxy $ VirtualFilterChain.doFilter(FilterChainProxy.java:331)       在org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:114)       在org.springframework.security.web.FilterChainProxy $ VirtualFilterChain.doFilter(FilterChainProxy.java:331)       在org.springframework.security.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:137)       在org.springframework.security.web.FilterChainProxy $ VirtualFilterChain.doFilter(FilterChainProxy.java:331)       在org.springframework.security.web.authentication.AnonymousAuthenticationFilter.doFilter(AnonymousAuthenticationFilter.java:111)       在org.springframework.security.web.FilterChainProxy $ VirtualFilterChain.doFilter(FilterChainProxy.java:331)       在org.springframework.security.web.servletapi.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:170)       在org.springframework.security.web.FilterChainProxy $ VirtualFilterChain.doFilter(FilterChainProxy.java:331)       在org.springframework.security.web.savedrequest.RequestCacheAwareFilter.doFilter(RequestCacheAwareFilter.java:63)       在org.springframework.security.web.FilterChainProxy $ VirtualFilterChain.doFilter(FilterChainProxy.java:331)       在org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:116)       在org.springframework.security.web.FilterChainProxy $ VirtualFilterChain.doFilter(FilterChainProxy.java:331)       在org.springframework.security.web.header.HeaderWriterFilter.doFilterInternal(HeaderWriterFilter.java:64)       在org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)       在org.springframework.security.web.FilterChainProxy $ VirtualFilterChain.doFilter(FilterChainProxy.java:331)       在org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:105)       在org.springframework.security.web.FilterChainProxy $ VirtualFilterChain.doFilter(FilterChainProxy.java:331)       在org.springframework.security.web.context.request.async.WebAsyncManagerIntegrationFilter.doFilterInternal(WebAsyncManagerIntegrationFilter.java:56)       在org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)       在org.springframework.security.web.FilterChainProxy $ VirtualFilterChain.doFilter(FilterChainProxy.java:331)       在org.springframework.security.web.FilterChainProxy.doFilterInternal(FilterChainProxy.java:214)       在org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:177)       在org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:350)       在org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:265)       在weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:78)       在org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:99)       在org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)       在weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:78)       在org.springframework.web.filter.HttpPutFormContentFilter.doFilterInternal(HttpPutFormContentFilter.java:105)       在org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)       在weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:78)       在org.springframework.web.filter.HiddenHttpMethodFilter.doFilterInternal(HiddenHttpMethodFilter.java:81)       在org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)       在weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:78)       在org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:199)       在org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)       在weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:78)       在org.springframework.boot.web.servlet.support.ErrorPageFilter.doFilter(ErrorPageFilter.java:115)       在org.springframework.boot.web.servlet.support.ErrorPageFilter.access $ 000(ErrorPageFilter.java:59)       在org.springframework.boot.web.servlet.support.ErrorPageFilter $ 1.doFilterInternal(ErrorPageFilter.java:90)       在org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)       在org.springframework.boot.web.servlet.support.ErrorPageFilter.doFilter(ErrorPageFilter.java:108)       在weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:78)       at weblogic.servlet.internal.WebAppServletContext $ ServletInvocationAction.wrapRun(WebAppServletContext.java:3654)       at weblogic.servlet.internal.WebAppServletContext $ ServletInvocationAction.run(WebAppServletContext.java:3620)       在weblogic.security.acl.internal.AuthenticatedSubject.doAs(AuthenticatedSubject.java:326)       在weblogic.security.service.SecurityManager.runAsForUserCode(SecurityManager.java:196)       在weblogic.servlet.provider.WlsSecurityProvider.runAsForUserCode(WlsSecurityProvider.java:203)       在weblogic.servlet.provider.WlsSubjectHandle.run(WlsSubjectHandle.java:71)       在weblogic.servlet.internal.WebAppServletContext.doSecuredExecute(WebAppServletContext.java:2423)       在weblogic.servlet.internal.WebAppServletContext.securedExecute(WebAppServletContext.java:2280)       在weblogic.servlet.internal.WebAppServletContext.execute(WebAppServletContext.java:2258)       在weblogic.servlet.internal.ServletRequestImpl.runInternal(ServletRequestImpl.java:1626)       在weblogic.servlet.internal.ServletRequestImpl.run(ServletRequestImpl.java:1586)       在weblogic.servlet.provider.ContainerSupportProviderImpl $ WlsRequestExecutor.run(ContainerSupportProviderImpl.java:270)       at weblogic.invocation.ComponentInvocationContextManager._runAs(ComponentInvocationContextManager.java:348)       at weblogic.invocation.ComponentInvocationContextManager.runAs(ComponentInvocationContextManager.java:333)       在weblogic.work.LivePartitionUtility.doRunWorkUnderContext(LivePartitionUtility.java:54)       在weblogic.work.PartitionUtility.runWorkUnderContext(PartitionUtility.java:41)       at weblogic.work.SelfTuningWorkManagerImpl.runWorkUnderContext(SelfTuningWorkManagerImpl.java:617)       在weblogic.work.ExecuteThread.execute(ExecuteThread.java:397)       在weblogic.work.ExecuteThread.run(ExecuteThread.java:346)   引起:javax.persistence.RollbackException:提交事务时出错       在org.hibernate.internal.ExceptionConverterImpl.convertCommitException(ExceptionConverterImpl.java:75)       at org.hibernate.engine.transaction.internal.TransactionImpl.commit(TransactionImpl.java:71)       在org.springframework.orm.jpa.ExtendedEntityManagerCreator $ ExtendedEntityManagerSynchronization.afterCommit(ExtendedEntityManagerCreator.java:462)       ......还有109个   引起:java.sql.SQLException:交易不再有效 - 状态:'已提交'。此事务中不允许进一步的JDBC访问。       在weblogic.jdbc.wrapper.JTSConnection.checkIfRolledBack(JTSConnection.java:205)       在weblogic.jdbc.wrapper.JTSConnection.checkConnection(JTSConnection.java:216)       在weblogic.jdbc.wrapper.JTSConnection.commit(JTSConnection.java:683)       at org.hibernate.resource.jdbc.internal.AbstractLogicalConnectionImplementor.commit(AbstractLogicalConnectionImplementor.java:81)       at org.hibernate.resource.transaction.backend.jdbc.internal.JdbcResourceLocalTransactionCoordinatorImpl $ TransactionDriverControlImpl.commit(JdbcResourceLocalTransactionCoordinatorImpl.java:221)       在org.hibernate.engine.transaction.internal.TransactionImpl.commit(TransactionImpl.java:68)       ......再多110个

不工作的控制器:

@RestController
@RequestMapping("/demographic")
@SuppressWarnings("rawtypes")
public class VerificationController {

    @Autowired
    EntityManager entityManager;

    public final Logger logger = LoggerFactory.getLogger(this.getClass());


    @Autowired
    private UserRepository userRepo;
    @Autowired
    private RoleRepository roleRepo;
    @Autowired
    private VerificationRepository veRepository;

    @PostMapping(value = "/validate")
    @ResponseBody
    public ResponseDTO Verification(@RequestBody VerificationModel verificationModel) throws IOException {
        logger.info("-----Start of Method------ ");
        logger.info("verify");
        logger.debug("Request  :" + verificationModel);

        ResponseDTO responseDTO = new ResponseDTO();
        VerificationLog verificationLog = new VerificationLog();

        // General Elements
        verificationLog.setAadharNumber("290567459087");
        verificationLog.setVerificationType("pi");
        verificationLog.setVerifiedBy("superadmin");
        verificationLog.setUploadedDate(new Date());
        verificationLog.setIsBulkUpload(false);

        // Default Values
        verificationLog.setAge(0);
        verificationLog.setMatchPercentage(0);

        logger.debug("Request to be Added :" + verificationLog);
        VerificationLog verificationLog1 = veRepository.save(verificationLog);

        logger.debug("Request to be Added :" + verificationLog1);

工作控制员:

@RestController
@RequestMapping("/user")
@SuppressWarnings("rawtypes")
public class UserController {

    @Autowired
    EntityManager entityManager;

    public final Logger logger = LoggerFactory.getLogger(this.getClass());

@PostMapping(value = "/createadmin")
    @ResponseBody
    public ResponseDTO createAdminUser(@RequestBody User user) {
        logger.info("-----Start of Method------ ");
        logger.info("createadmin");
        logger.debug("Request  :" + user);
        ResponseDTO responseDto = new ResponseDTO();

        try {
            Object object = userRepo.findAdminUser(user.getUserName());
            if (object == null) {
                user.setIsActive(true);
                User createdUser = userRepo.save(user);         

                UserRole newUserRole = new UserRole();
                newUserRole.setUserName(createdUser.getUserName());
                newUserRole.setRole("ROLE_ADMIN");
                roleRepo.save(newUserRole);

                responseDto.setResult("Created");

                List list = userRepo.findAllAdminUsers();
                List<UserResponseDTO> admins = new ArrayList<UserResponseDTO>();
                for (int i = 0; i < list.size(); i++) {
                    Object[] row = (Object[]) list.get(i);
                    admins.add(new UserResponseDTO((String) row[0], (String) row[1], (Boolean) row[2]));
                }
                responseDto.setData(admins);
            } else {
                responseDto.setResult("Already Exists");
            }
        } catch (Exception e) {
            logger.error("Exception :" + e.getMessage());
            logger.warn("Stack Trace :" + e.getStackTrace());
        }
        logger.debug("Response :" + responseDto);
        logger.info("-----End of Method------ ");
        return responseDto;
    }

BeanConfig:

@Configuration
@EnableMBeanExport(registration = RegistrationPolicy.IGNORE_EXISTING)
public class BeanConfig {

    @SuppressWarnings("deprecation")
    @Bean
    public LocalContainerEntityManagerFactoryBean entityManagerFactory() {
        LocalContainerEntityManagerFactoryBean lemb = new LocalContainerEntityManagerFactoryBean();
        lemb.setDataSource(getJndiObjectFactoryBean());
        lemb.setJpaVendorAdapter(jpaVendorAdapter());
        lemb.setJpaDialect(new HibernateJpaDialect());
        // lemb.setJ
        Properties prop = new Properties();
        prop.put(org.hibernate.cfg.Environment.RELEASE_CONNECTIONS, ConnectionReleaseMode.AFTER_STATEMENT);
        // prop.put(org.hibernate.cfg.annotations.IdBagBinder.)
        lemb.setJpaProperties(prop);
        lemb.setPackagesToScan(new String[] { ("com.aadhaar.verify.model"), ("com.aadhaar.verify.response") });
        return lemb;

    }

    public JpaVendorAdapter jpaVendorAdapter() {
        HibernateJpaVendorAdapter jpaVendorAdapter = new HibernateJpaVendorAdapter();
        jpaVendorAdapter.setShowSql(false);
        jpaVendorAdapter.setGenerateDdl(false);
        // jpaVendorAdapter.setDatabase(Database.MYSQL);
        return jpaVendorAdapter;
    }

    @Bean
    public DataSource getJndiObjectFactoryBean() {
        // ComboPooledDataSource datasource = new ComboPooledDataSource();;
        // try {
        // datasource.setDriverClass("oracle.jdbc.driver.OracleDriver");
        // } catch (PropertyVetoException e) {
        // // TODO Auto-generated catch block
        // e.printStackTrace();
        // }

        // datasource.setMinPoolSize(5);
        // datasource.setMaxIdleTime(2000);
        // datasource.setMaxPoolSize(20);
        // datasource.setMaxStatements(2000);
        // return datasource;
        JndiObjectFactoryBean jobjFac = new JndiObjectFactoryBean();
        jobjFac.setJndiName("jdbc/AppzillonServerDS");
        try {
            jobjFac.setResourceRef(true);
            jobjFac.setProxyInterface(DataSource.class);
            jobjFac.afterPropertiesSet();
        } catch (IllegalArgumentException | NamingException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();        
        }
        return (DataSource) jobjFac.getObject();
        /*
         * JndiDataSourceLookup dataSourceLookup = new JndiDataSourceLookup();
         * DataSource dataSource =
         * dataSourceLookup.getDataSource("jdbc/AppzillonServerDS"); return
         * dataSource;
         */
    }

1 个答案:

答案 0 :(得分:0)

尝试添加此属性

Properties prop = new Properties();
prop.put("hibernate.connection.release_mode", "auto");
prop.put("hibernate.connection.handling_mode", "DELAYED_ACQUISITION_AND_RELEASE_AFTER_STATEMENT");