Проблема Doctrine n+1 с отношением ManyToMany, несмотря на использование загрузки EAGERPhp

Кемеровские программисты php общаются здесь
Ответить
Anonymous
 Проблема Doctrine n+1 с отношением ManyToMany, несмотря на использование загрузки EAGER

Сообщение Anonymous »

Я тестирую платформу API и столкнулся с проблемами n+1 с Doctrine. У меня есть объект под названием Car, который имеет отношение ManyToMany с Driver. Я не делал ничего особенного, я просто тестирую платформу API в состоянии по умолчанию (по-видимому).
Субъект Car:

Код: Выделить всё

#[ORM\ManyToMany(targetEntity: Driver::class, mappedBy: 'car', fetch: 'EAGER')]
#[ORM\JoinTable(name: "cars_to_drivers")]
private Collection $drivers;
Сущность драйвера:

Код: Выделить всё

 #[ORM\ManyToMany(targetEntity: Car::class, mappedBy: 'driver', fetch: 'EAGER')]
#[ORM\JoinTable(name: "cars_to_drivers")]
private Collection $cars;
Когда я нажимаю конечную точку GET, чтобы получить автомобили (30 на страницу), я вижу в профилировщике Doctrine, что выполняется 32 запроса: один для получения количества, один для получения всех автомобилей и один запрос на каждую машину для получения водителей для этой машины. Кажется, Doctrine настаивает на создании этих дополнительных запросов, несмотря на то, что я принудительно загружаю их. Как мне решить эту проблему?

Подробнее здесь: https://stackoverflow.com/questions/758 ... er-loading
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Php»