Так что это все равно 0 (n), но это 1n, а не 2n. Чтобы избежать ненужных выборок, я решил эту проблему, используя пользовательский класс репозитория и конструктор запросов doctrine, например:
namespace BRS\PageBundle\Repository;
use Doctrine\ORM\EntityRepository;
class ContentRepository extends EntityRepository
{
public function reorder($content)
{
$em = $this->getEntityManager();
$count = 0;
foreach($content as $i => $content_id){
$q = $em->createQuery('update BRSPageBundle:Content c set c.display_order = ?1 where c.id = ?2')
->setParameter(1, $i)
->setParameter(2, $content_id);
$count += $q->execute();
}
return $count;
}
}
затем скажите, что у вас есть массив идентификаторов контента в следующем порядке:
$content = array(23,12,8,4);
Затем вы можете обновить заказ с вашего контроллера довольно просто:
$count = $this->getRepository('BRSPageBundle:Content')->reorder($content);