Я тестирую платформу 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