Optimization Symfony-更新多个记录

Optimization Symfony-更新多个记录,optimization,doctrine,symfony,Optimization,Doctrine,Symfony,使用条令symfony2更新数据库中多个记录的最佳方法是什么 我收到需要更新的记录ID数组。 我想为每个记录分配从接收数组到列show_顺序的索引。 所以,如果我收到array$array=array(22,1,5,10),那么我想 $i = 0; foreach($array as $a) { $record = $this->getDoctrine->getRepository('AcmeBundle:SomeEntity')->findOneById($a);

使用条令symfony2更新数据库中多个记录的最佳方法是什么

我收到需要更新的记录ID数组。
我想为每个记录分配从接收数组到列show_顺序的索引。 所以,如果我收到array$array=array(22,1,5,10),那么我想

 $i = 0;
 foreach($array as $a) {
    $record = $this->getDoctrine->getRepository('AcmeBundle:SomeEntity')->findOneById($a);
    if ($record != null) $record->setOrder($i++);
 }
 $this->getDoctrine()->getEntityManager()->flush();
但这是一种可怕的方式,因为对于每个记录,我只做一次选择,所以查询的数量是O(n)

如何做得更好?

类似于

foreach ($repo->findById($ids) as $obj) {
    $obj->setOrder(array_search($obj->getId(), $ids));
}

$em->flush();
这仍然是0(n),但它是1n而不是2n。为了避免不必要的选择,我使用了和条令查询生成器解决了这个问题,如下所示:

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;
    }
}
然后假设您有一个按如下顺序排列的内容ID数组:

$content = array(23,12,8,4);
然后,您可以从控制器更新订单,非常简单:

$count = $this->getRepository('BRSPageBundle:Content')->reorder($content);

我现在有一个想法:获取所有记录,检查哪个顺序已经改变,只更新它们。但我并不满足于这个解决方案。因此,它将进行一次选择以获取所有记录,很少进行选择(以获取实体对象)和很少进行更新(或者可能是一次,因为我认为更新是在flush()之后调用的)。如果使用doctrine2没有好的解决方案,也许我应该在clear PHP和用例中完成,当。。。然后。。。在sql查询中?对我来说很好-一次选择,一次更新。我完全忘记了我可以在findById中将数组作为参数传递。:)我刚刚在我的symfony项目中实现了这一点,通过查看app/dev.log,它对每个记录执行一次选择和一次更新,而不是一次更新