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

Вопрос по составлению запроса в Eloquent. Для модели нужно подгрузить отношение

rel1. Для тех из них кто rel1->where('prop1', true) нужно грузить вложенные отношения with(['rel1.nested.deep_nested']).

Сейчас получается только ч помощью loadMissing после первого запроса где только жадная загрузка rel1.

Есть возможность грузануть одним билдером или вариант загрузки loadMissing в два этапа единственно возможный?

8 ответов

10 просмотров

with или load([ 'rel1' => fn($query) => $query->where('prop1', true), 'rel1.nested.deep_nested', ]) вроде так

Egor Gruzdev
with или load([ 'rel1' => fn($query) => $query...

with или load([ 'rel1' => fn($query) => $query->where('prop1', true)->with('nested.deep_nested'), ])

Артур-Макаров Автор вопроса
Egor Gruzdev
with или load([ 'rel1' => fn($query) => $query...

если правильно помню то в результате останутся только rel1 где prop1 === true. А нужны все rel1 с любым значением. а ленивая загрузка вложеных отношений только для случая где prop1 === true

Артур Макаров
если правильно помню то в результате останутся тол...

т.е. тебе нужно nested.deep_nested только для rel1 где prop1 === true?

Артур Макаров
да

т.е. если у тебя $result это коллекция, то $result->load('rel1'); $result->where('rel1.prop1', true)->load('nested.deep_nested'); может так? т.е. получили результат, к нему подтянули rel1, выбрали только те, где rel1.prop1 === true и к ним подгрузили нужные связи, главное теперь там где будет обращение к связям не вмазаться в незагруженные связи

G'olib
А whereHas не вариант получше ?

У меня также вначале промелькнула такая мысль, но если ещё раз прочитать задачу, то нет

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

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

Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
32
Хотел бы спросить у знающих, правильную ли я выбрал книгу для начала изучения ассемблера Юрова В.И ? Или есть более лучшие книги для начала обучения?
Botsman
25
Книга Юрова В.И пойдёт для обучения?
Botsman
24
$params = [ 'formid' => 'feedbackForm', 'formTpl' => '@CODE: <form class="form-validate" data-id="ajax_form"> <fieldset class="margin-bottom-md"> ...
Pathologic
1
Подскажите пожалуйста, а я могу вот такую штуку использовать? rpc, только реализованное в реббите https://www.rabbitmq.com/tutorials/tutorial-six-php ( или https://habr.com/ru...
Artyom
11
а мы ещё не созрели до того, чтобы создать отдельный чатик про настройку редакторов?
Cheese Syrowiecki
16
И ещё вопрос: можно ли типа как на дос как-то запариться и с помощью прерываний выводить текст, вместо функции printf ?
НѣкъиⰘижєжєиꙁъвьсєсвѣтьноѣсѣтиѥсть•
34
Всем привет! У меня почему-то по-разному отображается TListView в Debug и Release режимах (FireMonkey)! При запуске под Win приложения TListView заливается программо. в Debug ...
Александр COM
8
Ладно, ещё тупого спрошу. Код должен банально вывести значение регистра на консоль, на деле же не выводя ничего, просто оставляя нерабочую консоль (открыта, ничего не написан...
НѣкъиⰘижєжєиꙁъвьсєсвѣтьноѣсѣтиѥсть•
25
Парни, спасайте. RAD Studio 12 творит какую-то дичь. У меня есть метод (event), который вызывает другой метод, т.е. он состоит из 1-й строки вызова. Ставлю бряк на event, запу...
Eugene Krasnikov (ᴊɪɴ x)
3
Карта сайта