面向对象中有继承的概念,而关系型数据库却没有表与表之间的继承关系。解决思路有三种:

1.  继承关系层次一个表:

    含义:使用一个表保存同一继承层次中的所有类,加额外字段来表示所属子类。

    优点:多态查询,查询父类和所有子类数据时只需一次简单的查询,性能最佳;

    缺点:在数据库表里添加各个区分子类的字段。

    适用:需要多态查询,且子类的属性较少。

2.  每个具体类一个表:

    含义:父类抽象化不对应一个表,每个子类对应一个表(每个子表包括父和子所有字段)。

    优点:实现的继承映射最简单。

    缺点:多态查询持久化对象效率最低,表中字段重复。

    适用:父类将来不会修改,且不需多态查询。

3.  每个子类一个表:

    含义:继承关系的父类和子类分别对应一个表,并通过外键产生关联。

    优点:符合常规设计规则,类与表的映射匹配更合理。

    缺点:复杂类继承下,需要同时操作多个表,查询时也需要多表的连接查询,性能不好。

    适用:需要多态查询,同时子类有较多的新增属性。