Возвращать только уникальные значения в раскрывающемся списке формы symfony 3.4

Я сделал форму, которая отправляет родительские организации отдельного пользователя. Таблица базы данных, с которой связана сущность, содержит несколько записей для организации (поскольку с каждой организацией связано несколько пользователей), и я хочу вернуть только один экземпляр имени организации, а не 20 дубликатов.

Я слышал, что есть такие функции, как unique () или findOneOrNull, но я не уверен, как их реализовать.

Вот код из формы:

        ->add(
            'userParent',
            EntityType::class,
            [   

                'class' => UserParent::class,
                'choice_label' => function ($parents) {
                    return $parents->getParent()->getName();
                }
            ]
        )               
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
0
0
313
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Вам следует использовать построитель запросов: https://symfony.com/doc/current/reference/forms/types/entity.html#ref-form-entity-query-builder При этом вы можете создать собственный запрос, какие объекты вы хотите отображать. Но одна лань! Если вы группируете записи из таблицы, это означает, что вы будете ссылаться только на одну конкретную строку из двойников ... это звучит немного странно.

Ответ принят как подходящий

Вы можете указать QueryBuilder для EntityType:

->add('userParent',
      EntityType::class,
      [   
          'class' => UserParent::class,
          'choice_label' => function ($parents) {
              return $parents->getParent()->getName();
          },
          'query_builder' => function(UserParentRepository $r) {
                                 return $r->getUniqueCompanies();
          },
      ]
    );

Затем вам нужно будет добавить getUniqueCompanies() в класс UserParentRepository, здесь поможет DISTINCT.

Когда я использую этот запрос, появляется ошибка: «Предупреждение: spl_object_hash () ожидает, что параметр 1 будет объектом, строка дает»

symi khan 25.05.2019 07:26

Другие вопросы по теме