![](/img/trans.png)
[英]Spring data using EntityManager: NullPointerException
[英]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.