面向对象中有继承的概念,而关系型数据库却没有表与表之间的继承关系。解决思路有三种:
1. 继承关系层次一个表:
含义:使用一个表保存同一继承层次中的所有类,加额外字段来表示所属子类。
优点:多态查询,查询父类和所有子类数据时只需一次简单的查询,性能最佳;
缺点:在数据库表里添加各个区分子类的字段。
适用:需要多态查询,且子类的属性较少。
2. 每个具体类一个表:
含义:父类抽象化不对应一个表,每个子类对应一个表(每个子表包括父和子所有字段)。
优点:实现的继承映射最简单。
缺点:多态查询持久化对象效率最低,表中字段重复。
适用:父类将来不会修改,且不需多态查询。
3. 每个子类一个表:
含义:继承关系的父类和子类分别对应一个表,并通过外键产生关联。
优点:符合常规设计规则,类与表的映射匹配更合理。
缺点:复杂类继承下,需要同时操作多个表,查询时也需要多表的连接查询,性能不好。
适用:需要多态查询,同时子类有较多的新增属性。
时间: 2024-10-12 08:27:28