169 похожих чатов

Подскажите, есть ли какой-то легкий способ, получить hasOneThrough через 2

таблицы?
Например, предположим, что в примере из доки есть еще сверху таблица с фирмами(компаниями) 'companies', которая выглядит так:
companies:
id - integer
name - string

а в таблице механиков дополнена связью с фирмами
mechanics:
id - integer
name - string
company_id - integer

Есть ли способ сделать в Owner доступ к Компании типа так:
public function company(): HasOneThrough
{
return $this->hasOneThrough(Company::class, [Car::class, Mechanic::class]);
}

Видел в сети вроде какой-то пакет есть для этого, но не охота его ставить пока что. Может есть какие-то удобные штатные средства, не описанные в доке?
🤔

28 ответов

44 просмотра

попробуй типа public function company(): BelongsTo { return $this->car->mechanic->company(); } при условии что все связи описаны

только пакетом

Vladyslav
такое не заработает)

у меня работает, просто через 1 а не через 2

Serhii Dorn
у меня работает, просто через 1 а не через 2

ну не знаю, как то оно страшно выглядит

DevilSAM- Автор вопроса
Serhii Dorn
у меня работает, просто через 1 а не через 2

у меня тоже так работает через 2 связи. Не совсем релэйшен, конечно, но мне пойдет 😅 return Company::find($owner->car?->mechanic?->company_id)

DevilSAM- Автор вопроса
Vladyslav
фуфуфу

да мне надо это один раз в одном месте вывести )) не, это не внутри модели. Это уже по коду, где выводить надо

DevilSAM- Автор вопроса

это надо company() иметь внутри Owner. А что я там могу предложить?

DevilSAM
это надо company() иметь внутри Owner. А что я там...

public function company(): BelongsTo { return $this->car->mechanic->company(); }

DevilSAM- Автор вопроса
Serhii Dorn
public function company(): BelongsTo { ...

кстати, работает! ⚡️

Serhii Dorn
public function company(): BelongsTo { ...

Плохая реализация. Здесь нужно оставить релейшен в car, далее в модели car релейшен на механика, а в модели механика - на компанию. Снаружи используется жадная загрузка: with('car.mechanic.company') И, в том числе, избавляемся от проблемы N+1 в запросах.

DevilSAM- Автор вопроса
Andrey Helldar
Плохая реализация. Здесь нужно оставить релейшен в...

а разве with() не вернем нам билдер вместо релейшена?

DevilSAM
а разве with() не вернем нам билдер вместо релейше...

https://laravel.com/docs/10.x/eloquent-relationships#eager-loading

DevilSAM
а разве with() не вернем нам билдер вместо релейше...

Сам метод возвращает билдер, а вот результат запроса будет содержать загруженные релейшены

DevilSAM- Автор вопроса
Andrey Helldar
Сам метод возвращает билдер, а вот результат запро...

а... предлагается не писать релейшен для модели owner, а просто использовать жадную загрузку для получения данных.

DevilSAM
а... предлагается не писать релейшен для модели ow...

Жадная загрузка загружает релейшены. Не писать их невозможно

DevilSAM- Автор вопроса
Andrey Helldar
Жадная загрузка загружает релейшены. Не писать их ...

я имею ввиду конкретный релейшен company для модели owner. все остальные релейшены, конечно, остаются

DevilSAM- Автор вопроса
Andrey Helldar
Жадная загрузка загружает релейшены. Не писать их ...

то есть return Owner::with('car.machanic.company')->find($owner->id)?->car?->machanic?->company лучше чем return Company::find($owner->car?->mechanic?->company_id)

DevilSAM
то есть return Owner::with('car.machanic.company')...

а зачем делать Owner::find('$owner->id') ?)

DevilSAM
то есть return Owner::with('car.machanic.company')...

Зачем грузить овнера, если уже есть его модель? $owner->car->mechanic->company

DevilSAM- Автор вопроса
Andrey Helldar
Зачем грузить овнера, если уже есть его модель? $...

так... я не успеваю )) чем вот это лучше того, что было изначально?

DevilSAM- Автор вопроса
DevilSAM
так... я не успеваю )) чем вот это лучше того, чт...

ленивая загрузка нужна при массовой загрузке записей, ->get()

Похожие вопросы

Обсуждают сегодня

а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
63
Эх кто-то пришел и весь праздник испортил :( You need complex FBX scene importing setup to change things on import? good luck with that. You need navigation and pathfinding? g...
Serg Gini
5
Какого хера? /Sources/App/Modules/User/Models/UserLinkApple.swift:21:20: warning: stored property '_id' of 'Sendable'-conforming class 'UserLinkApple' is mutable @ID(...
Alexander Sherbakov
14
Всем привет! Подскажите. Я написал приложение на Delphi 10.2 Tokyo под Windows 10. И передо мной стал вопрос о том чтобы сделать это приложение кроссплатформенным (под Linux и...
Дмитрий Завгородний
24
Привет всем. Подскажите где можно посмотреть, какая версия электрон, поддерживает версии windows? Некий changelog. Мне бы желательно, поддержку 7,8,10... latest, как понимаю и...
Anonym Squad
21
Почему стало ломаться на D11? "739002.86400000' is not a valid timestamp" function IncDateTime(aStamp:TTimeStamp;aKind:TTriggerKind;aInterval:Integer):TDateTime; //aStamp = 2...
Катерина Свиридова
8
У тебя в конфиге нигде нет deny all; или вообще любого deny?
Alexander Sherbakov
10
Портфолио: Зовут меня Александр, мне 36 лет. Город Пушкино. Общий рабочий стаж: ~14 лет Уровень квалификации: Senior Full-stack developer Где прочесть мой код? https://github....
Magic
10
Ребят, чет я уже не догоняю... Крч в коде на асм там происходит нечто вроде a+число (a+1, a+2 и т.д.). Но почему строка lea ecx, [edx+1] работает как a+1?? В edx берется адрес...
Alan 🔝 Бэброу
4
думаешь я не смогу также сделать? мне это просто не удобно
int 💳 𝙖𝙞𝙧 𝙗𝙞𝙜 𝙗𝙤𝙗 🔫 check bio / spam block / AFK / nohello.com / GMT+3
9
Карта сайта