Доктрина: модели Hydrate из необработанного SQL

У меня есть следующий пользовательский запрос. Я знаю, что он простой, поэтому его также можно использовать как DQL, но у меня есть и более сложные. Но я хочу знать, как это сделать, даже с более сложными запросами.

select j.*
from `shop`.`jobs` j
-- 2 joins
where j.`active` = true 
order by j.`priority` desc, j.`created` asc 

Конечно, есть Job модель.

Что я хочу:

Массив экземпляров из класса Job, использующий сырой sql. Как это:

array (6) {
    [0] => Job#12 (8) {
      ...
    }
    [1] => Job#13 (8) {
      ...
    }
    [2] => Job#14 (8) {
      ...
    }
    [3] => Job#16 (8) {
      ...
    }
    [4] => Job#17 (8) {
      ...
    }
    [5] => Job#18 (8( {
      ...
    }
}

1 ответ

Нашел это! С помощью функции createNativeQuery EntityManager. А для RSM мне нужно использовать класс ResultSetMappingBuilder.

$rsm = new \Doctrine\ORM\Query\ResultSetMappingBuilder($this->getEntitiyManager());
$rsm->addRootEntityFromClassMetadata(\Path\To\Model::class, 'alias');

$nativeQuery = $this->getEntitiyManager()->createNativeQuery('-- query--', $rsm);

$nativeQuery->getResult();
Другие вопросы по тегам