假设我有以下两个实体:
@Entity
public class Employee {
String name;
@ManyToOne Department department;
}
@Entity
public class Department {
// persisted flieds ...
@OneToMany(mappedBy="department") Collection<Employee> employees;
}
及其相应的表在两个不同的模式oldSchema和newSchema中定义,具有不同的内容,如下所示:
- oldschema.Department,oldSchema.Employee
- newSchema.Department、newSchema.Employee
我正在使用newSchema,
我想做的是从 oldSchema 中检索一个 Department 实体对象,以及它的 Employee 集合。
我得到的是来自旧模式的部门实体,但具有来自新模式的员工集合。
我正在使用的代码:
Query q = entityManager.createNativeQuery("SELECT * FROM
oldSchema.Department d where d.departmentID = ?", Department.class);
q.setParameter(1, depID);
try{
Department d = (Department) q.getSingleResult();
}catch(exception){}
对象d包含存储在newSchema.Employee中的Employees集合
这是由于自动模式演变所致,如此处针对 ObjectDB https://www.objectdb.com/java/jpa/entity/schema 所解释的那样。在我的例子中,这似乎与 EclipseLink 相同,如果我错了,请纠正我。
非常感谢您的帮助!
最佳答案
在 persistence.xml 或 orm.xml 或您使用的任何内容中创建更多持久性单元。每个模式一个持久性单元。每个模式一个实体管理器/工厂。
关于java - 使用 JPA 时是否可以禁用自动模式演化?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54884492/