Получить содержимое ArrayCollection
Я хотел бы обновить мой проект Symfony 2 с версии 2.3 до 2.7 LTS. У меня есть проблема в хранилище, чтобы получить результат запроса. В 2.3 этот запрос дает мне кое-что:
public function findProtectedPublications( $steps, $start, $end)
{
$query= $this->getEntityManager()
->createQueryBuilder()
->select('d.pubRefs')
->from('ImpressionDemandBundle:Event', 'h')
->innerJoin('h.demand','d')
->where('d.protectedPublications = :pub')
->setParameter('pub', 1 )
->andWhere('h.date >= :start')
->setParameter('start', $start )
->andWhere('h.date <= :end')
->setParameter('end', $end )
->andWhere('h.stepId in (:steps)')
->setParameter('steps', $steps )
->orderBy('d.id','ASC')
->getQuery();
$results = $query->getResult();
$publications = array();
if ($results && ! empty ($results)){
foreach($results as $result){
$pubs = $result['pubRefs'];
if ($pubs && ! empty($pubs)){
foreach($pubs as $pub){
$publications[] = $pub;
}
}
}
}
return $publications;
}
Но этот код не работает в более ранней версии, потому что переменная $pubs в ArrayCollection. Таким образом, я изменил конец моего кода следующим образом:
$results = $query->getResult();
$publications = array();
if ($results && ! empty ($results)){
foreach($results as $result){
$pubs = $result['pubRefs'];
var_dump($pubs);
if (! $pubs->isEmpty()){
$arrayPubs = $pubs->toArray();
foreach($arrayPubs as $pub){
$publications[] = $pub;
}
}
}
}
return $publications;
В этой части, когда я дам дамп переменной $pubs, у меня будет:
object(Doctrine\Common\Collections\ArrayCollection)#131 (2) {
["elements":"Doctrine\Common\Collections\ArrayCollection":private]=>
NULL
["_elements":"Doctrine\Common\Collections\ArrayCollection":private]=>
array(1) {
[0]=>
object(Impression\DemandBundle\Entity\Publication)#125 (5) {
["editor":"Impression\DemandBundle\Entity\Publication":private]=>
string(24) "Journal Le Monde 4-10-13"
["coauthors":"Impression\DemandBundle\Entity\Publication":private]=>
string(12) "Machin Machin"
["title":"Impression\DemandBundle\Entity\Publication":private]=>
string(57) "La tragédie de Lampedusa: s"émouvoir, comprendre, agir."
["nbPages":"Impression\DemandBundle\Entity\Publication":private]=>
float(1)
["nbCopies":"Impression\DemandBundle\Entity\Publication":private]=>
float(40)
}
}
}
Таким образом, кажется, что в этой коллекции ArrayCollection есть элементы, но тест $pubs->isEmpty() дает истинный результат, поэтому у меня ничего нет в массиве $ публикаций.
Изменить: На самом деле, проблема, кажется, из-за моих данных в базе данных: для объекта, предшествующего моему обновлению, у меня есть что-то вроде этого в базе данных:
O:43:"Doctrine\Common\Collections\ArrayCollection":1:{s:54:"Doctrine\Common\Collections\ArrayCollection_elements";a:1:{i:0;O:42:"Impression\DemandBundle\Entity\Publication":5:{s:50:"Impression\DemandBundle\Entity\Publicationeditor";s:5:"BREAL";s:53:"Impression\DemandBundle\Entity\Publicationcoauthors";s:5:"MONOT";s:49:"Impression\DemandBundle\Entity\Publicationtitle";s:18:"USA Canada mexique";s:51:"Impression\DemandBundle\Entity\PublicationnbPages";d:150;s:52:"Impression\DemandBundle\Entity\PublicationnbCopies";d:150;}}}
и это дает ошибку. Для объекта, добавленного после моего обновления, у меня есть что-то вроде этого в базе данных:
O:43:"Doctrine\Common\Collections\ArrayCollection":1:{s:53:"Doctrine\Common\Collections\ArrayCollectionelements";a:1:{i:0;O:42:"Impression\DemandBundle\Entity\Publication":5:{s:50:"Impression\DemandBundle\Entity\Publicationeditor";s:8:"dfg dfgd";s:53:"Impression\DemandBundle\Entity\Publicationcoauthors";s:7:"dfg dfg";s:49:"Impression\DemandBundle\Entity\Publicationtitle";s:5:"fdg d";s:51:"Impression\DemandBundle\Entity\PublicationnbPages";d:5;s:52:"Impression\DemandBundle\Entity\PublicationnbCopies";d:3;}}}
и функция findProtectedPublications() работает без ошибок.
Разница между двумя версиями заключается в ArrayCollection_elements для первой и ArrayCollectionelements для второй.
Чтобы исправить эти данные, я попытался с
UPDATE demand SET pub_refs = REPLACE (pub_refs, "ArrayCollection_elements', 'ArrayCollectionelements')
но это не работает из-за специальных символов. Пытаясь с
UPDATE demand SET pub_refs = REPLACE (pub_refs, "ArrayCollection�_elements', 'ArrayCollection�elements')
не работает лучше Как я могу исправить эти данные?
2 ответа
Doctrine может заполнять результаты как Array вместо ArrayCollection, просто изменив getResult()
позвонить:
$results = $query->getResult(\Doctrine\ORM\AbstractQuery::HYDRATE_ARRAY);
Это был бы наиболее эффективный способ выполнить вашу задачу, однако вы также можете использовать встроенный в ArrayCollection toArray()
Метод для преобразования своих данных в формат массива:
$publications = $results->toArray();
Поскольку проблема, по-видимому, связана с изменением хранилища ArrayCollection в базе данных между версиями Symfony 2.3 и 2.7, я создал команду строки, чтобы обновить их в базе данных.