如何配置在Symfony2项目中扩展PersistentObject的Doctrine2实体?

时间:2013-06-13 14:11:33

标签: php symfony doctrine-orm

我希望能够在开发Symfony2项目期间使用此处描述的PersistentObject http://www.doctrine-project.org/blog/a-doctrine-orm-odm-base-class.html,以避免在数据库和实体设计不断变化时无休止地创建和删除getter和setter。

在Symfony2项目中,如“简要文档”(下面的代码引用)中所建议的那样“配置”ObjectManager?应该在控制器中,如果是,它会是什么样的?

 $entityManager = EntityManager::create(...);
 PersistentObject::setObjectManager($entityManager);

我找不到任何有用的例子(虽然我确实在stackoverflow上找到了Zend2框架的这个相似例子:Using PersistentObject from Doctrine in Zend Framework

谢谢你的时间!

1 个答案:

答案 0 :(得分:1)

PersistentObject是一个您不需要手动持久保存的对象。因此,它使用php的__call()方法提供魔法getter和setter

您只需在实体类中扩展Object并在控制器中使用它。无需生成getter和setter。

示例实体

<?php
namespace Vendor\YourBundle\YourEntity;

use Doctrine\Common\Persistence\PersistentObject; 
use Doctrine\Common\Persistence\ObjectManager;
use Doctrine\ORM\Mapping as ORM;

class YourEntity extends PersistentObject
{

   // i added the constructor in order to save the setObjectManager() 
   // call in the the controller

   public function __construct(ObjectManager $om)
   {
       $this->setObjectManager($om);
   }

   /** 
    * @ORM\Id  
    * @ORM\Column(type="integer")
    * @ORM\GeneratedValue(strategy="AUTO")
    */
   protected $id;

   /**
    * @ORM\Column(type="string", length=100)
    */
   protected $name;

   // ... more properties

}

示例控制器操作

class YourController extends Controller
{
    public function yourAction($name)
    {
        $em = $this->get('doctrine')->getManager('default');

        $entity = new YourEntity($em);   // __construct calls setObjectManager($em)

        $entity->setName($name);         // magic setter is used here

        // ... no need for $em->persist($entity);

        $em->flush();                    // $entity is being persisted.
    }

    // ...

使用...之一获取symfony控制器内的doctrine实体管理器。

 $em = $this->get('doctrine')->getManager();          // gets default manager
 $em = $this->get('doctrine')->getManager('default'); // same as above
 $em = $this->getDoctrine()->getManager();            // using alias