提问者:小点点

错误:关系方法必须返回Illumb\Database\Eloquent\Relations\Relations类型的对象


我正在尝试返回属于文件路由中相同案例的多个会话。php:

Route::get('company/case/{case_id}/session/', ['before' => 'auth|can:view_all_sessions*view_own_sessions', 'uses' => 'SessionController@index', 'as' => 'company.session.index']);

控制器:: SessionController.php:

    public function index($case_id) {
    $case = LawCase::findOrFail($case_id);

    $sessions = $case->sessions()->orderBy(Input::get('field', 'date'), Input::get('sort', 'desc'))
        ->paginate(20);

    $data = [
        'sessions' => $sessions,
        'form' => null,
        'title' => trans('links.sessions'),
        'case' => $case,
        'case_id' => $case_id
    ];

    $this->layout->section = View::make('session.index', $data);
}

模型类:: LawSession.php:

    public function lawcase() {
    return $this->belongsTo(LawCase::class, 'case_id');
}

模型类:: LawCase.php:

public function sessions() {
    return $this->hasMany(LawSession::class, 'case_id');
}

我得到了这个错误:

关系方法必须返回类型为照明\数据库\雄辩\关系\关系的对象


共2个答案

匿名用户

这将有助于:

dd($case->getRelations());

你在那里看到你的亲戚了吗?如果是,请执行以下操作:

dd($case->sessions);

是否返回相关数据?

如果这不能帮助找到问题,请共享完整的堆栈跟踪。没有日志很难猜测解决方案。

您可以在以下位置找到日志:

/storage/logs/laravel.php

匿名用户

只需在SessionController中修改这一行。php

$sessions=$case-

并使数据库中存在关系记录。