OneToMany / ManyToOne SchemaException - PullRequest
       7

OneToMany / ManyToOne SchemaException

6 голосов
/ 05 июня 2011

Я пытаюсь построить отношение manyToOne для моего приложения Symfony2 с Doctrine2.Я получаю эту ошибку, и я не знаю, почему:

app/console doctrine:schema:create
PHP Deprecated:  Comments starting with '#' are deprecated in /etc/php5/cli/conf.d/mcrypt.ini on line 1 in Unknown on line 0
ATTENTION: This operation should not be executed in an production enviroment.


  [Doctrine\DBAL\Schema\SchemaException]
  There is no column with name 'activityGroup' on table 'activity'.  

Это два класса: http://pastebin.com/Ev7Rwgxr

Я думаю, что на самом деле есть IS ActivityGroup в классе Activity ... такчто пытается сказать эта ошибка?

Спасибо!

1 Ответ

8 голосов
/ 06 июня 2011

Я понял ...

уникальные ограничения ожидают, что настоящее имя поля БД будет activityGroup_id, а не просто activityGroup.

Можно убедиться, что поле называетсяв БД, предоставляя JoinColumn.

Итак, умное решение:

    /**
     * @ORM\Entity
     * @ORM\Table(name="activity",
     *     uniqueConstraints={
     *         @ORM\UniqueConstraint(name="name_idx", columns={"activity_group_id", "name"}),
     *         @ORM\UniqueConstraint(name="sort_idx", columns={"activity_group_id", "sort_id"})
     *     }
     * )
     */
    class Activity
    {
        // ...

        /**
         * @ORM\ManyToOne(targetEntity="SeduceMe\SiteBundle\Entity\ActivityGroup", inversedBy="activities")
         * @ORM\JoinColumn(name="activity_group_id", referencedColumnName="id")
         */

        protected $activityGroup;
        //...
    }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...