初级学说需要实体关系援助


Beginner Doctrine Entity Relationship Assistance Needed

我是条令的新手,很难建立我的第一个实体关系/关联。

我想要以下两张桌子:

Kitchen
- ID
- Name
- Description
- MainImage
KitchenImage
- ID
- KitchenID (ref Kitchen.ID)
- Image

每个厨房都会有一张主照片和一大堆子照片。

以下是我目前的两个条令文件(删除了格式化的get和setter):

厨房

/**
 * @ORM'Entity
 * @ORM'Table(name="kitchen")
 */
class Kitchen
{
    /**
     * @ORM'Id
     * @ORM'Column(type="integer")
     * @ORM'GeneratedValue(strategy="AUTO")
     */
    protected $id;
    /**
     * @ORM'Column(type="string", length=100)
     */
    protected $name;
    /**
     * @ORM'Column(type="text")
     */
    protected $description;
    /**
     * @ORM'Column(type="string", length=255)
     */
    protected $image;
    /**
     * @ORM'OneToMany(targetEntity="KitchenImage", mappedBy="kitchen")
     */
    protected $images;
    public function __construct()
    {
        $this->images = new ArrayCollection();
    }
}

厨房图像

/**
 * KitchenImage
 *
 * @ORM'Table(name="kitchen_image")
 * @ORM'Entity
 */
class KitchenImage
{
    /**
     * @var integer
     *
     * @ORM'Column(name="id", type="integer")
     * @ORM'Id
     * @ORM'GeneratedValue(strategy="AUTO")
     */
    protected $id;
    /**
     * @var string
     *
     * @ORM'Column(name="image", type="string", length=255)
     */
    protected $image;
    /**
     * @ORM'ManyToOne(targetEntity="Kitchen", inversedBy="images")
     * @ORM'JoinColumn(name="kitchen_id", referencedColumnName="id")
     */
    protected $kitchen;
}

PHP函数:

public function createAction()
    {
        $kitchen = new Kitchen();
        $kitchen->setName('Example Kitchen');
        $kitchen->setDescription('Big amount of text to go here...');
        $kitchen->setImage('front-image.jpg');
        $image1 = new KitchenImage();
        $image1->setImage('1.jpg');
        $image2 = new KitchenImage();
        $image2->setImage('2.jpg');
        $kitchen->addImage($image1);
        $kitchen->addImage($image2);
        $em = $this->getDoctrine()->getManager();
        $em->persist($kitchen);
        $em->flush();
        return new Response('success');
    }

错误响应

A new entity was found through the relationship 'PWD'WebsiteBundle'Entity'Kitchen#images' that was not configured to cascade persist operations for entity: PWD'WebsiteBundle'Entity'KitchenImage@0000000009670754000000003a9b3dc9. To solve this issue: Either explicitly call EntityManager#persist() on this unknown entity or configure cascade persist this association in the mapping for example @ManyToOne(..,cascade={"persist"}). If you cannot find out which entity causes the problem implement 'PWD'WebsiteBundle'Entity'KitchenImage#__toString()' to get a clue.

我做错了什么?

您需要替换这段代码:

$em = $this->getDoctrine()->getManager();
$em->persist($kitchen);
$em->flush();

有了这个:

$em = $this->getDoctrine()->getManager();
$em->persist($image1);
$em->persist($image2);
$em->persist($kitchen);
$em->flush();