У меня есть следующий код для получения окончательных данных $result2
.
$agent = auth()->user()->id;
$result = App\AgentStatus->select('callId')->where(function($query)use($agent) {
$query->where('agentId', '=', $agent);
})->first();
$result2 = NULL;
if($result != NULL) {
$id = $result->callId;
$calls = App\CallStatus->where(function($query)use($id) {
$query->where('callId', '=', $id);
})->first();
$id = $calls->callerId;
$result2 = App\Callout->where(function($query)use($id) {
$query->where('number', '=', $id);
})->first();
}
Модель:
AgentStatus:
protected $primaryKey = 'agentId';
CallStatus
protected $primaryKey = 'callId';
Выноска: первичный ключ - строка id
Это первый проект, над которым я работаю с laravel, и я хотел изменить приведенный выше код на что-то, что реализует отношения и нетерпеливую загрузку. Пока он работает, но может работать слишком медленно, если в таблицах намного больше строк.