我有3个人物,角色和位置模型代表足球俱乐部中的人
public class Person {
private Long id;
private String name;
private Role role;
}
public class Role {
private Long id;
private String name; //like manager, goalkeeping_coach, player
}
public class Position {
private Long id;
private String name; //striker, midfielder, defender, goalkeeper
}
问题是,只有当一个人扮演角色时,职位才有意义.所以如果我这样做
public class Person {
private Long id;
private String name;
private Role role;
private Position position;
}
那么对于所有没有角色的人实例,位置字段将存储空值.同样,可能还有其他属性仅对经理和/或goalkeeping_coach实例有意义.
我试图使Person类抽象
@Inheritance(strategy = InheritanceType.TABLE_PER_CLASS)
public abstract class Person {
private Long id;
private String name;
private Role role;
}
public class Player extends Person {
private Position position;
}
public class Manager extends Person {
}
这将导致播放器和管理器实例保存在不同的表中.但是,如果人的角色发生变化(例如球员退休并成为俱乐部的经理),就会出现问题.然后,我不得不将该行从一个表移动到另一个表(例如删除播放器实例,并使用相同的数据(不包括位置数据)创建一个新的经理实例),这似乎不是一个好方法.
那么处理这种情况的最佳方法是什么?是否可以像第一种情况一样具有空值?
解决方法:
要求是可以更改人员和角色之间的联系.
该模型可以反映出,如果为该连接以及“人”和“位置”之间的连接创建表格,
// Person table has only Person details
public class Person {
private Long id;
private String name;
}
// Role table has only Role details
public class Role {
private Long id;
private String name; //like manager, goalkeeping_coach, player
}
// Position table has only ...
public class Position {
private Long id;
private String name; //striker, midfielder, defender, goalkeeper
}
// connection of Person and Role
public class PersonRole {
private Long person_id;
private Long role_id;
}
// connection of Person and Position
public class PersonPosition {
private Long person_id;
private Long position_id;
}
该设计解决了人员更换角色的要求以及职位的条件相关性.它还可以满足将来的要求,例如具有多个角色和职位的人
编辑:
我发现我所描述的实际上是数据库模型.在Java中,您可以将连接表建模为多对多关系(如果使用某些ORM)
标签:architecture,java,model 来源: https://codeday.me/bug/20191108/2006631.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。