Использование значения столбца как индекса массива в доктрине

Я использую доктрину 2.1, чтобы создать модель для таблицы settings :

 id | arg | value | category 1 | name | foo | general_settings 2 | desc | bar | general_settings 

Предположим, что у меня много настроек для разных категорий. Чтобы получить все настройки для определенной категории, я делаю что-то вроде этого:

 $q = Doctrine_Query::create() ->from('Setting p') ->where('p.category = ?', $category_name); 

На данный момент все отлично работает. Ну .. вопрос о 64 000 $: Есть ли альтернатива доступа к данным, которые позволяют мне читать результат, как показано ниже?

 $resultSet = $q->execute(); //the magic here could be use the -arg- column as index $requested_setting = $resulSet['name'] //print the setting value echo $requested_setting['value']; //should prints "foo" //another way echo $resulSet['desc']['value']; //should prints "bar" 

Solutions Collecting From Web of "Использование значения столбца как индекса массива в доктрине"

Я понял: здесь используется слово INDEX BY .

Класс запроса

импортируйте класс запроса (необязательно всегда):

 use \Doctrine\ORM\Query; 

создайте запрос:

 $query = $this->data->em->createQuery(' SELECT s FROM models\Setting s INDEX BY s.arg //to set array custom key WHERE s.category = :category'); $query->setParameter('category', 'general'); 

установите режим hidration для работы с массивами только для чтения

 $settings = $query->getResult(Query::HYDRATE_ARRAY); 

Отобразите значение:

 echo $settings['desc']['value']; // prints "bar" 

QueryBuilder

С объектом QueryBuilder вы можете установить индекс в инструкции from :

 $qb = $em->createQueryBuilder(); $qb->select('s'); $qb->from('models\Settings', 's', 's.arg'); // here the magic $result = $qb->getQuery()->getResult(); 

Затем вы можете получить доступ к объекту как:

 $description = $result['desc']; $value = $description->getValue(); 

FYI при использовании createQueryBuilder в вашем EntityRepository, вы можете напрямую указать INDEX BY вместе с псевдонимом:

 $this->createQueryBuilder('p', 'p.id') 

Это позволяет избежать обработки вручную, из которой автоматически обрабатывается EntityRepositories.