该应用程序有以下模型:
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()
(参见上面链接的文档)。
attach()
用于多对多关系。看来你的关系应该是多对多的,但你还没有正确设置它。
class Intervencao extends Eloquent {
public function atividades() {
return $this->belongsToMany('Atividade');
}
}
然后attach()
应该工作