该应用程序具有以下模型:
class Atividade extends Eloquent {
public function intervencoes() {
return $this->belongsToMany('Intervencao');
}
}
class Intervencao extends Eloquent {
public function atividades() {
return $this->hasMany('Atividade');
}
}
以下代码有效:
Atividade::find($id)->intervencoes()->attach($intervencao_id);
但是这个...
Intervencao::find($id)->atividades()->attach($atividade_id);
返回BadMethodCallException:
调用未定义的方法Illuminate \ Database \ Query \ Builder :: attach()
我试图建立多对多关系,因此只需更改此...
return $this->hasMany('Atividade');
对此:
return $this->belongsToMany('Atividade');
请参阅以下Laravel文档:http ://laravel.com/docs/eloquent#inserting-related-models
基本上,您为相同的两个表设置了两种不同类型的关系-您已经建立了多对多和一对多的关系。似乎您可能想要多对多,因此您需要更改此行:
return $this->hasMany('Atividade');
对此:
return $this->belongsToMany('Atividade');
这会将关系设置为多对多关系,然后将支持该attach()
方法。
该attach()
方法仅适用于多对多,对于其他关系,则存在save()
或saveMany()
和associate()
(请参见上面链接的文档)。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句