当我尝试到达特定端点时,出现异常消息“无法为unitName parent_module检索EntityManagerFactory”
但是,由于在模块上构建了项目,因此出现了此错误。当我将所有内容都放在父模块中并且将包装标签作为war时,它可以正常工作而没有任何错误。
当我在模块上构建项目,并将父包装标签设为pom,将子包装标签设为war时,我开始遇到上述异常。
请注意,我在正确的路径中有persistence.xml。
CHILD_MODULE / src / main / resources / META-INF / persistence.xml
无论如何,只要我在父模块中移动文件,只要它能完美地工作,配置就应该很好。
persistence.xml在执行时出现在目标文件夹中。
我已经尝试过像@PersistenceContext(unitName =“ parent_module”)一样对EntityManager进行注释,但是我遇到了同样的异常。
persistence.xml
<?xml version="1.0" encoding="UTF-8"?>
<persistence xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
version="2.0"
xmlns="http://java.sun.com/xml/ns/persistence"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
<persistence-unit name="parent_module"
transaction-type="JTA">
<jta-data-source>jdbc/postgres.myproject</jta-data-source>
<mapping-file>META-INF/core-entity-mappings.xml</mapping-file>
</persistence-unit>
</persistence>
public abstract class AbstractAccessBA {
@PersistenceContext
protected EntityManager entityManager;
/**
* Flush all changes from the entity manager to the database
*/
public void flush() {
entityManager.flush();
}
}
public class WorkAccessBA extends AbstractAccessBA {
@Inject
private WorkMapper workMapper;
/**
* Finds all the entries
* @return a list of workBE
*/
public List<WorkBE> findAll() {
CriteriaBuilder cb = entityManager.getCriteriaBuilder();
CriteriaQuery<WorkBE> cq = cb.createQuery(WorkBE.class);
Root<WorkBE> rootEntry = cq.from(WorkBE.class);
CriteriaQuery<WorkBE> all = cq.select(rootEntry);
TypedQuery<WorkBE> allQuery = entityManager.createQuery(all);
return allQuery.getResultList();
}
它应该返回所有已建立结果的列表(同样,如果我移动父模块中的所有文件,这将起作用),但是当我移动文件(子模块中的配置,其包装标签为“ war”时,它会起作用)返回我描述的错误。
“无法为unitName parent_module检索EntityManagerFactory”
最佳答案
自己找到答案。问题出在glassfish / domains / nameOftheDomain / applications中
在使用父子模块构建应用程序之前,我曾使用过parent_module SNAPSHOT作为战争部署。
关于java - 无法检索unitName的EntityManagerFactory,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/56037130/