Ruby on Rails,一对一关联(One-to-One)
在上一篇文章中,我们列举了对象之间可能出现的关联关系。接下来,逐个分析一下每一种关系如何在Ruby on Rails中实现和使用。
他们的特点是,对象之间存在唯一的拥有关系。如果一个雇员也可以有多台电脑,不过这就不是今天的话题了,那是一对多关系(One-to-Many)。
场景2:将一张表的内容分离成两张(多张)表,比如他们的特点是,本来这些信息可以放在同一个表中,通过不同的列表示属性。不过为了逻辑更为清晰,将比较独立的属性从主表中拆分出来单独存储。还有一个好处就是,好多情况下主表(病人)信息被访问的几率较大,而从表(住院档案)属性很多并且查询几率较少时,将一个大表分离为多个表可以提高数据库使用效率。
不过说实话,实际应用中依然是较少有机会使用一对一关联,取而代之的应该是一对多关联。
举个例子,一般来说一个顾客只有一个账单地址。但是貌似应该也有多个账单地址的情况。建立对象关系的时候还是要考虑使用一对多关联以应对这种变化。
第3:一般来说需要在A、B类中定义对方的引用,以便能够通过一方找到另一方。
从头开始创建教室和老师模型类
> class_room.teacher = teacher> teacher.class_room = class_room> class_room.teacher=> #<Teacher id: 1, class_room_id: 1, name: "abbuggy", created_at: "2012-12-08 17:36:05", updated_at: "2012-12-08 17:37:05">