转的O/R Mapping经验

今天开始对项目的数据进行OR MAPPING,我根据使用HIBERNATE的经验来做,到也不觉得很困难,现在对这部分总结一下.
    说到OR MAPPING,总体来说要根据OO的特性来做,即"封装","继承","多态".而"多态"实际上是个动态的概念,因此MAPPING工作的重点就是"封装"和"继承".而"封装"中除了数据的封装外,还有实体间关系的表示.具体来看,无非这么几种关系:
    一对一
    一对多(多对一)
    多对多
    这次系统数据结构的设计没有用到继承,所以仅仅针对封装的这几种关系来说.
   
    一对一
    RAILS使用一对"has_one"和"belongs_to"来描述这种关系,等同于hibernate里的一对""和""
    一对多(多对一)
    这种关系也可以被称为双象映射,但是这里的双方关系却不是对称的.RAILS使用一对"has_many"和"belongs_to"来表示,等同于hibernate里面的和.
    多对多
    这种关系的表示得需要一个中间表,hibernate的做法是程序员得指定告诉hibernate这个中间表是谁,而rails的做法是规定死了,这个中间表的名子是两个关联表名中间加个下划线,并且,这两个表名以字母顺序排列,比如表A和表B有多对多关联,则这个中间表必需为A_B.实现上,是通过在双方加上"has_and_belongs_to_many"来实现,比hibernate简化了不少.不过,如果字母一样怎么办?比如rights跟roles的关联表.这个我还没有试验.

    总结来看,建立起静态关联关系是很容易的,不过这种关联关系在访问的时候具体如何来维护?有什么规则?这还需要在写业务代码时再考虑了.
 
发布了16 篇原创文章 · 获赞 2 · 访问量 9万+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章