单表继承:
面向对象开发时,经常会用到类和继承.如应用程序中有几个模型有一些属性是共有的
人员(People):顾客(Customer)、员工(Employee)和经理(Manager)
因此,创建模型:Customer类和Employee类,且都是People的子类,Manager类是Employee的子类。子类会继承父类的所有属性和行为。
我们可以这样来设计: 建一张名为people的表并以此作为类,
里面的字段包含了人的基本属性和一个type字段,用来标记每个实例的类型
当各个模型之间只有细微的差别时,就可以考虑使用单表继承(STI)
不同角色的人员,均保存于people表。
如果子类存在的差异较大,且属性数据较大,如果仍然存在于同一张表,就会产生很多问题。
多态关联:
一个模型同时与多个其它模型之间发生一对多的关联
比如 商店(Story)有很多员工(Employee)、经理(Manager)和 顾客(Customer)
员工(Employee)、经理(Manager)和 顾客(Customer)属于 商店(Story)
我们为每一个 类 创建一个表 将表进行关联。
还有一个例子:
Comment(评论)表, 一个Topic应该有Comment(一个帖子应该有许多的评论),除此之外Micropost(微博)也可能有很多的Comment。
当然我们可以建两个独立的表比如TopicComment和MicropostComment,再分别关联到Topic和Micropost上,但这不是一种好的选择,我们可以只建一个表(Comment),然后去关联这两个表
comments的表,表的每一列都是一个评论,然后有两个字段来标记这条评论是来评论哪个主题文章的,这个字段可以是commentable_type(用来标记评论类型), commentable_id(用来标记具体某个评论主题).这样,我们只要根据类型和id就可以定位关联到具体的某个评论主题.