继承这个概念做java开发的同学应该都很熟悉了,继承指的是子类继承父类的特征和行为,使得子类对象(实例)具有父类的实例域和方法,或子类从父类继承方法,使得子类具有父类相同的行为。数据库设计的时候也是有继承关系的,在数据库设计方法论中继承有三种,分别是具体表继承(Concrete Table Inheritance)、单表继承(Single Table Inheritance)、类表继承(Class Table Inheritance)。我们实际设计中经常会不经意中使用到数据库到继承,下面分别介绍一下他们的概念:
假如你现在在做个教学系统,系统中有三个角色:学生、家长、老师。
学生的属性:姓名、年龄、性别、身份证、入学时间、学号、学分 家长的属性:姓名、年龄、性别、职业、学历 老师的属性:姓名、年龄、性别、教龄、学科、是否已婚
不同继承方案的实现如下:
union
操作(如:页面需要展示所有的用户,显示用户的公共字段)
使用场景:适用于子表关联性较弱的业务场景,并且识别出系统没有公共数据查询的需求数据库设计的原则就是没有原则,需要根据业务场景选择具体的设计方法。
今天说的数据库继承方案或者数据库范式都是这样,并不是说你数据库设计的扩展性强或者完全遵循4NF范式消除一切数据一致性问题就最好,设计带来的join查询效率也需要慎重考虑。