繁体   English   中英

无法使用Spring Managed EntityManager保留数据

[英]Not able to persist data using spring managed EntityManager

我再次需要您的帮助,我试图将Hibernate + Spring集成到我的独立Java应用程序中,但是数据库操作无法正常工作,但是注入了我通过调试验证的entitymanager,所以我不确定代码/中缺少什么配置,我通过谷歌搜索进行了一些研究,但没有找到解决我问题的方法。 因此,我正在发布我的代码/配置,以便有人可以帮助我摆脱这些。

实体类:

      package com.entity;

      import javax.persistence.Column;
      import javax.persistence.Entity;
      import javax.persistence.GeneratedValue;
      import javax.persistence.GenerationType;
      import javax.persistence.Id;
      import javax.persistence.Table;

      @Entity
      @Table(name = "employee")
      public class Employee {

               @Id
               @GeneratedValue(strategy =  GenerationType.AUTO)
               @Column(name = "EMP_ID")
               private Integer empoyeeId;

               @Column(name = "EMP_NAME")
               private String employeeName;

               public Integer getEmpoyeeId() {
                     return this.empoyeeId;
               }

               public void setEmpoyeeId(Integer empoyeeId) {
                     this.empoyeeId = empoyeeId;
               }

               public String getEmployeeName() {
                     return this.employeeName;
               }

               public void setEmployeeName(String employeeName) {
                   this.employeeName = employeeName;
               }
       }

道课

  package com.dao.impl;

  import javax.persistence.EntityManager;

  import com.dao.IEmployeeDao;
  import com.entity.Employee;

  public class EmployeeDao implements IEmployeeDao {

        private static final Logger LOGGER = 
                  LogManager.getLogger(EmployeeDao.class);

        @PersistenceContext(unitName = "testPU")
        private EntityManager em;

        @Override
        public Employee create(Employee aEmployee) {
           return this.em.merge(aEmployee);
        }

        @Override
        public Employee fetchEmployeeById(Integer aEmployeeId) {
         return this.em.find(Employee.class, aEmployeeId);
        }
  }

主要课程:

    package com.client;

    import org.apache.logging.log4j.LogManager;
    import org.apache.logging.log4j.Logger;
    import org.springframework.beans.BeansException;
    import org.springframework.context.ApplicationContext;
    import org.springframework.context.support.ClassPathXmlApplicationContext;

    import com.dao.IEmployeeDao;
    import com.entity.Employee;

    public class Client {
           private static final Logger LOGGER = LogManager.getLogger(Client.class);

           public static void main(String[] args) throws BeansException, 
                   Exception {
                   ApplicationContext applicationContext = new 
                   ClassPathXmlApplicationContext("applicationcontext.xml");
                   LOGGER.info("client invoked");
                   IEmployeeDao employeeDao =  
                   (IEmployeeDao)applicationContext.getBean("employeeDao");
                   Employee employee = new Employee();
                   employee.setEmployeeName("Suraj Kumar");
                   employee = employeeDao.create(employee);
                   employee =                        
                   employeeDao.fetchEmployeeById(employee.getEmpoyeeId());  
                   //getting null pointer here as employee is null

                   //       EntityManagerFactory emf = 
                           Persistence.createEntityManagerFactory("testPU");
                  //        EntityManager em = emf.createEntityManager();
                  //        em.getTransaction().begin();
                  //        EmployeeDao employeeDao = new EmployeeDao();
                  //        employeeDao.setEm(em);
                  //        Employee employee = new Employee();
                  //        employee.setEmployeeName("Suraj Kumar");
                  //        employee = employeeDao.create(employee);
                  //        employee = 
                    employeeDao.fetchEmployeeById(employee.getEmpoyeeId());
                  //        em.getTransaction().commit();
                  //        em.close();
                  //        emf.close();
          }
     }

使用上面的客户端代码,当尝试通过id来获取雇员时,我得到了null指针异常,因为create调用返回的雇员返回的null断言该记录未持久。

但是,当我通过注释上面未注释的代码并注释掉现在注释的代码来关闭spring时,即当我仅使用休眠而不使用spring时,一切正常。 我在下面提供了配置文件。

applicationcontext.xml:

    <?xml version="1.0" encoding="UTF-8"?>
    <beans xmlns="http://www.springframework.org/schema/beans"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xmlns:aop="http://www.springframework.org/schema/aop"
        xsi:schemaLocation="http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans-2.5.xsd ">
    <import resource="aspects.xml"/>

        <bean class="org.springframework.orm.jpa.support.
                     PersistenceAnnotationBeanPostProcessor"/>

        <bean id="myEmf" 
        class="org.springframework.orm.jpa.LocalEntityManagerFactoryBean">
            <property name="persistenceUnitName" value="testPU"/>
        </bean>

        <bean id="employeeDao" class="com.dao.impl.EmployeeDao" />

    </beans>

persistence.xml

   <?xml version="1.0" encoding="UTF-8"?>
   <persistence xmlns="http://java.sun.com/xml/ns/persistence"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://java.sun.com/xml/ns/persistence

   http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"
          version="2.0">
   <persistence-unit name="testPU" transaction-type="RESOURCE_LOCAL">
   <provider>org.hibernate.ejb.HibernatePersistence</provider>
   <class>com.entity.Employee</class>
   <exclude-unlisted-classes>true</exclude-unlisted-classes>
   <properties>
      <property name="hibernate.connection.url" 
                value="jdbc:mysql://localhost:3306/dbname"/>
      <property name="hibernate.connection.driver_class" 
                value="com.mysql.jdbc.Driver"/>

      <property name="hibernate.dialect" 
                value="org.hibernate.dialect.MySQLDialect"/>
      <property name="hibernate.connection.username" value="user"/>
      <property name="hibernate.connection.password" value="password"/>
      <property name="hbm2ddl.auto" value="update"/>
      </properties>
  </persistence-unit>
  </persistence>

我也在使用方面,但是我没有发布代码,因为我不确定在关闭方面时我是否尝试过关闭代码,即使遇到这个问题,关闭方面也只是发生了一件奇怪的事情,而不是得到一个空指针异常我从EntityManager类的find方法内部获得了另一个异常,该异常指示在这种情况下dao类的create方法不会返回null。

有人可以帮我吗?

似乎您的交易未提交。

尝试在EmployeeDao类的方法中添加@Transactional,或者甚至更好地创建一个Service层来处理事务并注释@Transactional的方法

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM