hasOne(多对一关系)

译者:飞龙

来源:hasOne

hasOne关联是一种多对一的关系,意思是你定义的模型可以有多个实例指向一个其它的实例(所属相同模型或不同模型)。

用法

  1. Animal.hasOne(association_name [, association_model [, options ] ]);

描述

  • association_name是两个模型之间的关系名称‘
  • association_model是要关联的另一个模型(如果没有定义,假设为同一个模型,大多数情况下这可能不是你想要的);
  • options是一个对象,拥有一些和关联有关的,你可以调整的属性,比如自动获取,再比如表(SQL中)或者集合(MongoDB中)的名称。

示例

  1. Animal.hasOne("owner", Person);

在背后,这条语句意思是Animal集合拥有一个属性owner_id(这个名称可以通过选项来修改,{field: 'ownerid'}),它会指向Person集合的某个人。如果关联并不是必须的,则可以为空。

这个关联也会创建一些额外的便利方法(叫做关联访问器)来帮助你管理它。访问器的名称也可以修改(同上,在选项里面),默认情况下,它们会拥有和关联名称相似的名称。例如,下面的代码展示了可以做类似这样的事情:

  1. // assuming John is a Person..
  2. Animal.find({ name: "Deco" }).first(function (err, Deco) {
  3. Deco.setOwner(John, function (err) {
  4. // John is now the owner of Deco
  5. });
  6. });

其它的访问器:

  • getOwner(callback) - 获取关联的所有者
  • hasOwner(callback) - (在回调中)返回这个动物是否拥有所有者
  • removeOwner(callback) - 移除和所有者的关联关系(如果存在的话)

关联反转

有时你希望通过对面的模型来访问关联。在上面的例子中,是通过Person。你可以向关联传递一个选项来实现它。

  1. Animal.hasOne('owner', Person, { reverse: "pets" });

之后,每个person实例都有有两个便利方法:

  • getPets(callback) - 获取所有和这个人有关联的动物
  • setPets(cat, dog, callback) - 移除所有和这个人有关联的动物,并且添加猫和狗