hasOne(多对一关系)
译者:飞龙
来源:hasOne
hasOne关联是一种多对一的关系,意思是你定义的模型可以有多个实例指向一个其它的实例(所属相同模型或不同模型)。
用法
Animal.hasOne(association_name [, association_model [, options ] ]);
描述
association_name
是两个模型之间的关系名称‘association_model
是要关联的另一个模型(如果没有定义,假设为同一个模型,大多数情况下这可能不是你想要的);options
是一个对象,拥有一些和关联有关的,你可以调整的属性,比如自动获取,再比如表(SQL中)或者集合(MongoDB中)的名称。
示例
Animal.hasOne("owner", Person);
在背后,这条语句意思是Animal
集合拥有一个属性owner_id
(这个名称可以通过选项来修改,{field: 'ownerid'}
),它会指向Person
集合的某个人。如果关联并不是必须的,则可以为空。
这个关联也会创建一些额外的便利方法(叫做关联访问器)来帮助你管理它。访问器的名称也可以修改(同上,在选项里面),默认情况下,它们会拥有和关联名称相似的名称。例如,下面的代码展示了可以做类似这样的事情:
// assuming John is a Person..
Animal.find({ name: "Deco" }).first(function (err, Deco) {
Deco.setOwner(John, function (err) {
// John is now the owner of Deco
});
});
其它的访问器:
getOwner(callback)
- 获取关联的所有者hasOwner(callback)
- (在回调中)返回这个动物是否拥有所有者removeOwner(callback)
- 移除和所有者的关联关系(如果存在的话)
关联反转
有时你希望通过对面的模型来访问关联。在上面的例子中,是通过Person
。你可以向关联传递一个选项来实现它。
Animal.hasOne('owner', Person, { reverse: "pets" });
之后,每个person
实例都有有两个便利方法:
getPets(callback)
- 获取所有和这个人有关联的动物setPets(cat, dog, callback)
- 移除所有和这个人有关联的动物,并且添加猫和狗