1

一直在尝试这样做一段时间,但我似乎无法让它工作......

基本上,我们有一个包含多个内容的页面。我试图得到它,所以当实体生成时,我们将能够做类似的事情$page->getContents()

当我运行教义:生成:实体命令时,它会跳过内容属性并且不会为其创建getter或setter....

它应该吗?如果没有,我需要做什么才能使其正常工作?

以下是文件:

<?php

namespace Foo\BarBundle\Entity;

use Doctrine\ORM\Mapping as ORM;

/**
 * Foo\BarBundle\Entity\Page
 *
 * @ORM\Table(name="page")
 * @ORM\Entity
 */
class Page
{
    /**
     * @var integer $pageId
     *
     * @ORM\Column(name="page_id", type="integer", nullable=false)
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="IDENTITY")
     */
    public $pageId;

    .......

    /**
     * @var \Foo\BarBundle\Entity\Content 
    *
     * @ORM\OneToMany(targetEntity="Content", mappedBy="page", cascade={"all"})
     */
    public $contents;
}

内容

<?php

namespace Foo\BarBundle\Entity;

use Doctrine\ORM\Mapping as ORM;

/**
 * Foo\BarBundle\Entity\Content
 *
 * @ORM\Table(name="content")
 * @ORM\Entity
 */
class Content
{
        /**
         * @var integer $contentId
         *
         * @ORM\Column(name="content_id", type="integer", nullable=false)
         * @ORM\Id
         * @ORM\GeneratedValue(strategy="IDENTITY")
         */
        public $contentId;

        .........

        /**
         * @var Page
         *
         * @ORM\ManyToOne(targetEntity="Page", inversedBy="contents")
         * @ORM\JoinColumns({
         *   @ORM\JoinColumn(name="page_id", referencedColumnName="page_id")
         * })
         */
        public $page;
}

架构

(取出不重要的列)

CREATE TABLE `page` (
  `page_id` int(32) unsigned NOT NULL AUTO_INCREMENT,
  PRIMARY KEY (`page_id`),
) ENGINE=InnoDB AUTO_INCREMENT=28 DEFAULT CHARSET=latin1;

CREATE TABLE `content` (
  `content_id` int(32) unsigned NOT NULL AUTO_INCREMENT,
  `page_id` int(32) unsigned NOT NULL,
  PRIMARY KEY (`content_id`),
  KEY `page_id` (`page_id`),
  CONSTRAINT `content_ibfk_1` FOREIGN KEY (`page_id`) REFERENCES `page` (`page_id`),
) ENGINE=InnoDB AUTO_INCREMENT=28 DEFAULT CHARSET=latin1;
4

2 回答 2

2

您是否尝试过验证您的实体?

    $em = $this->getDoctrine()->getEntityManager();
    $validator = new SchemaValidator($em);
    $errors = $validator->validateMapping();

希望这有助于安东尼诺

于 2012-09-27T22:39:45.630 回答
1

对不起,我来晚了 !

因此,如果您从数据库生成实体,您将拥有 php 实体(通常在 Entity\ 文件夹中),但在 xml/yml/php 中还有一个“映射文件”,默认情况下在 Resources/config/doctrine... 中创建。

So if you want to make an "fake" relation working you've to declare it in your orm file and your php entity.

Glad it helped you!

于 2012-10-01T15:24:50.593 回答