单表继承 (Single Table Inheritance)

概念   将类的继承层次表示为一个单表,表中的各列代表不同类中的所有域.
     说白了就是把含有继承关系的类的内容都保存到一个表中.当然为了区分类的层次,不至于找儿子却找到爹的尴尬局面,要增加一个字段来保存这个层次.
运行机制 
     在这个继承映射方案中,我们使用一个表包含某个继承层次中所有类的所有数据.每个类负责把与之相关的数据保存在表的一行中.数据库中其他不相关的列留空.
     在往内存中加载一个对象的时候,必须知道实例化哪个类来创建这个对象.为此,数据表中有一个域用来指示应该使用哪个类.它可能是类的名字也可能是一个代码域.
     加载数据的时候首先读代码,看看需要实例化哪个类.保存数据的时候代码需要由层次关系中的超类写出.
优点
    1.在数据库中只需要关注一个表.
    2.获取数据时不必进行连接操作.
    3.任何对继承层次的重构都不需要修改数据库.
缺点
    1.对那些使用数据库表的用户见到列的值时有时无会感到困惑.毕竟DBA可是不看我们写的Code的.而且现在企业强调的是系统的整合,Data往往不是只为你的Application存在的.
    2.只被某些子类使用的列会带来数据空间的浪费.当然这也要分什么样的数据库产品了,Oracle对这方面处理的就比较好.
    3.因为都存在一个表中,所以数据量会变的很大,有许多索引并被频繁上锁,从而导致访问该表时效率低下.

                

知识共享许可协议
本作品采用知识共享署名 2.5 中国大陆许可协议进行许可。必须保留本文的署名以及原文链接.
posted @ 2005-12-25 02:22  Vincent  阅读(1624)  评论(2编辑  收藏  举报