Wiz*_*zix 5 laravel eloquent lumen
我有两个模型,用户和事件.我invitations用一个status列在User和Event之间创建了一个数据透视表.在我的事件模型定义中,我写了这样的:
public function invited()
{
return $this->belongsToMany(User::class, 'invitations', 'event_id', 'user_id')
->withTimestamps()
->withPivot('status')
->orderByDesc('invitations.updated_at');
}
public function participants()
{
$event = $this->with([
'invited' => function ($query) {
$query->where('invitations.status', InvitationStatus::ACCEPTED)->get();
}
])->first();
return $event->invited;
}
Run Code Online (Sandbox Code Playgroud)
但是当我在我的控制器中时:
$event = Event::where('id', $id)->with(['owner', 'participants'])->first();
Run Code Online (Sandbox Code Playgroud)
我有以下错误:
(1/1) BadMethodCallException
Method addEagerConstraints does not exist.
Run Code Online (Sandbox Code Playgroud)
有人知道为什么吗?
当你想要这样做时:
->with('participants')
Run Code Online (Sandbox Code Playgroud)
Laravel希望得到一个关系实例.换句话说,您不能将此方法用作关系.
| 归档时间: |
|
| 查看次数: |
7658 次 |
| 最近记录: |