1

一位用户可能只有 1 个项目或没有。(1-1..0 关系)

我正试图在 symfony2 中通过教义来实现这一点。

我已经完成了一对一的关系,这相当简单。但是我如何指定当我想创建一个用户时,该项目可以为空?(而不是插入新行,只保留 id_item 为空)

这就是我所拥有的:

user.orm.yml 文件

oneToOne:
  userItem:
    targetEntity: SOA\AXBundle\Entity\Items
    cascade: ["remove", "persist"]
    joinColumn:
      name: id_item        
      referencedColumnName: id        
      nullable: true

当然,我创建了 ItemsTypeForm 类,并在我的 userstypeform 类中添加了类型:

    // UsersTypeForm Class
    ->add('userItem', new \SOA\AXBundle\Form\ItemsTypeForm())

Controller Action 是这样的,

public function addUserAction(Request $request) {

  $user = new User();

  $form = $this->createForm(new UseType(), $user);

  if ($request->getMethod() == 'POST') {

     $form->bindRequest($request);

     if ($form->isValid()) {

         $em = $this->getDoctrine()->getEntityManager();
         $em->persist($user);
         $em->flush();

         return $this->redirect($this->generateUrl('homepage'));
     }
  }

}

当我添加一个新用户时,一切都很好。用户和项目一样被插入。但是当我尝试添加一个没有项目的用户(用户项目字段为空白)时,我收到以下错误:

SQLSTATE[23000]: Integrity constraint violation: 1048 Column 'name' cannot be null

它正在尝试插入具有空值的项目。

虽然我可以接受 1 对 1 的关系,但我想学习如何建立 1 对 1..0 的关系。

4

1 回答 1

0

数据库模式没问题(您可以检查是否在用户表定义中直接查看您的数据库,我很确定您可以将 null 用于“item_id”字段)。

问题是当您填写表单并提交时,Symfony 会创建 Item 对象,其中每个字段都设置为 null(因为表单中与项目相关的每个字段都是空的)。您必须以某种方式告诉您,如果每个字段都为空,则框架不应保留 Item 对象。在我看来,实现这一目标的最佳方法是使用 DataTransformer。

你可以在这里读到它:

http://symfony.com/doc/2.0/cookbook/form/data_transformers.html

通常在transformer::reverseTransform 中检查每个字段是否为空,如果是,则返回null 而不是Item 对象。

于 2012-09-06T07:19:27.287 回答