我正在开发一个使用 Oracle 的内置“HR”数据库模式的示例 Java 应用程序。我想将表行视为 Java 对象。HR 模式中的一个表 EMPLOYEES 是自引用的。它有一个 MANAGER_ID 列,其中包含(如果不是 NULL)到 EMPLOYEES 表中另一行的外键。
在面向对象的术语中,问题是如何访问给定 Employee 对象的经理(这是另一个 Employee 对象)。急切加载似乎不是一个好的解决方案,因为给定的 Employee 对象的经理也可能有一个经理,等等。在这种情况下急切加载的对象数量是无限的。
到目前为止,我决定做的是在实例化 Employee 对象时急切地加载 MANAGER_ID 字段。然后,当 Employee 的经理 Employee 对象被请求时(通过一个getManager()
方法),后者将被延迟加载。在代码中:
public class Employee
{
private int id;
private int managerId;
private Employee manager;
public int getId()
{
return id;
}
public Employee getManager()
{
if(manager == null && managerId > 0)
{
// Lazy loading!
}
return manager;
}
public void setManager(Employee manager)
{
this.manager = manager;
this.managerId = manager.getId();
}
}
那么这是一个好方法吗?我唯一遇到的问题是如何实现延迟加载。Employee 对象似乎需要对其实例化器的引用——大概这与实例化其经理 Employee 对象相同。
另外,我知道我可以只使用许多 ORM 框架之一,而不是自己动手,但我自己这样做是为了更深入地了解底层流程。
编辑: 澄清一下,我的这项工作的架构(例如)根本不涉及 Java EE。它是一种 Java SE 架构,其中客户端通过简单的 RMI 与服务器交互。
此外,上面的 Employee 类显然确实需要对 DAO 的引用来执行延迟加载。但是,我认为这不一定是紧密耦合的,因为:
- Employee 对象可以持有对 DAO 实现的抽象接口的引用;和/或
- Employee 对象可以持有对服务器对象的引用,而服务器对象又持有对 DAO 的(私有)引用。
请注意,在 #2 的情况下,Employee 对象引用的服务器对象可能与客户端引用的服务器对象相同。