我正在制作一个系统(使用Spring + JPA和MySQL)来显示某个职位的最佳申请者。company
和applicants
有自己的user account
,有了它,它们就可以填写它们的personal/company information
和job profile/job offer conditions
了。这样,系统就应该将工作条件(如3+多年的C语言工作经验)与申请者的工作概况相匹配。
我的问题是,用户帐户是首先创建的,应该是独立的,但这两个具有不同属性的不同实体(申请人和公司)正在使用它。因此,如果我在用户帐户中创建一个applicant
和company
,其中一个将始终为空。
我该如何解决这个问题呢?我猜问题应该是这样的:如何实现一个用户帐户,该帐户可以保存来自具有不同属性的不同实体的数据(因此,不能分组)?(实际上,我还需要一个实体,但我尝试将其简化,以便更清楚地说明问题)。
发布于 2019-05-29 08:46:27
我认为,你应该制作标记界面,就像public interface UserAccountable
或smth。在您的Applicant
和Company
类中实现此接口。然后,您可以在UserAccount类中创建一个字段,如private UserAccountable someUser;
,并通过setter和getter将此变量赋值给Applicant或Company。希望这能有所帮助!
发布于 2019-05-30 06:13:29
我在这里找到了我需要的东西:https://thoughts-on-java.org/complete-guide-inheritance-strategies-jpa-hibernate/
问题在于映射,而不是类设计本身。我可以在Java世界中创建接口和抽象类来解决这个问题,但在SQL世界中这是不可能的,所以映射是关键。在本例中,我在寻找连接表映射,但我意识到我需要它只是为了在我的UserAccount
中不包含空字段,因为我不需要多态查询(例如,给我每个“用户类型”(Person
,Company
)的名称),而且以这种方式实现它在性能方面代价太高,所以我将牺牲空间来换取性能,并且我将在User Account
中引用所有三个用户类型,这将使这三个字段中的两个永远为空。
PS:单表映射不会有帮助,因为我确实需要使用not null
条件。
https://stackoverflow.com/questions/56351712
复制相似问题