Symfony2 и Doctrine2: для сущности «X» не указан идентификатор / первичный ключ. Каждый объект должен иметь идентификатор / первичный ключ

Я использую Symfony2 для создания фиктивных проектов. Я придерживаюсь документации Symfony2 Book, чтобы создать командную строку Entity with Doctrine (http://symfony.com/doc/current/book/doctrine.html#add-mapping-information). Я использую, таким образом, аннотации, простой объект Товар и никаких ассоциаций.

Я скопировал точный пример: я успешно создал базу данных и создал таблицу Product. Затем я удалил все и попытался воссоздать базу данных (все в порядке) и таблицу (проблема!), Только для целей тестирования.
Doctrine не может генерировать больше методов получения и установки и не может создавать таблицу в базе данных MySQL.

Здесь какой-то вывод

app/console doctrine:generate:entities MyBundle

> backing up Product.php to Product.php~
> generating MyBundle\Entity\Product

(nothing happens except for creating the identical backup file with no setters / getters added)

app/console doctrine:schema:validate
OR
app/console doctrine:schema:create
OR
app/console doctrine:schema:update --force
----------
[Doctrine\ORM\Mapping\MappingException]
No identifier/primary key specified for Entity "MyBundle\Entity\Product".
Every Entity must have an identifier/primary key.

doctrine:schema:validate [--em[="..."]]

Моя архитектура

PHP          5.5.21 (tried also with PHP 5.5.14)
Apache       2.4.9
Mac OSX      10.10.1 - Yosemite
MySQL        5
ENV          dev

Composer установленные пакеты

doctrine/annotations                 v1.2.3  Docblock Annotations Parser
doctrine/cache                       v1.4.0  Caching library offering an object-oriented API for many cache backends
doctrine/collections                 v1.2    Collections Abstraction library
doctrine/common                      v2.4.2  Common Library for Doctrine projects
doctrine/dbal                        v2.5.1  Database Abstraction Layer
doctrine/doctrine-bundle             v1.3.0  Symfony DoctrineBundle
doctrine/doctrine-cache-bundle       v1.0.1  Symfony2 Bundle for Doctrine Cache
doctrine/inflector                   v1.0.1  Common String Manipulations with regard to casing and singular/plural rules.
doctrine/lexer                       v1.0.1  Base library for a lexer that can be used in Top-Down, Recursive Descent Parsers.
doctrine/orm                         v2.4.7  Object-Relational-Mapper for PHP
incenteev/composer-parameter-handler v2.1.0  Composer script handling your ignored parameter file
jdorn/sql-formatter                  v1.2.17 a PHP SQL highlighting library
kriswallsmith/assetic                v1.2.1  Asset Management for PHP
monolog/monolog                      1.12.0  Sends your logs to files, sockets, inboxes, databases and various web services
psr/log                              1.0.0   Common interface for logging libraries
sensio/distribution-bundle           v3.0.15 Base bundle for Symfony Distributions
sensio/framework-extra-bundle        v3.0.4  This bundle provides a way to configure your controllers with annotations
sensio/generator-bundle              v2.5.1  This bundle generates code for you
sensiolabs/security-checker          v2.0.1  A security checker for your composer.lock
swiftmailer/swiftmailer              v5.3.1  Swiftmailer, free feature-rich PHP mailer
symfony/assetic-bundle               v2.6.0  Integrates Assetic into Symfony2
symfony/monolog-bundle               v2.7.1  Symfony MonologBundle
symfony/swiftmailer-bundle           v2.3.8  Symfony SwiftmailerBundle
symfony/symfony                      v2.6.3  The Symfony PHP framework
twig/extensions                      v1.2.0  Common additional features for Twig that do not directly belong in core
twig/twig                            v1.18.0 Twig, the flexible, fast, and secure template language for PHP

Мой код

Мой код точно такой же, как в документации к Symfony2 Book, за исключением имени Bundle, измененного на MyBundle. Структура файлов и папок правильно работает с другими функциями. Для проекта нет особых настроек, только основы.

namespace MyBundle\Entity;

use Doctrine\ORM\Mapping as ORM;

/**
* @ORM\Entity
* @ORM\Table(name="product")
*/
class Product
{
/**
* @ORM\Column(type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
protected $id;

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

/**
* @ORM\Column(type="decimal", scale=2)
*/
protected $price;

/**
* @ORM\Column(type="text")
*/
protected $description;
}

Уже пытался

  • Изменить разрешения проекта
  • Выполните «приложение / консоль доктрина: генерировать: лица» от имени пользователя root
  • Очистить кеш
    • казнить Кэш: прозрачный а также Кэш: прогрев
    • Вручную удалить папку кеша
  • Оставьте только идентификатор (в качестве первичного ключа) в сущности Product
  • Удалить и воссоздать всю базу данных
  • Удалить Product Entity, очистить кеш и заново создать все (вручную)
  • Обновите всех поставщиков
  • Проверены все двойные ** на аннотации
  • Изменить компьютер с той же архитектурой программного обеспечения
  • Я также казнил (спасибо @Srdjan)
    php app / console доктрина: кеш: очистить метаданные && доктрина приложения / консоли: cache: clear-query && доктрина приложения / консоли: cache: clear-result
    но геттеры и сеттеры не генерируются
  • Я удалил таблицу, базу данных и воссоздал шаг за шагом (спасибо @paistra)
  • Я пытался удалить таблицу с

    доктрина приложения / консоли: схема: падение

но ошибка всегда одинакова

[Doctrine\ORM\Mapping\MappingException]
No identifier/primary key specified for Entity "MyBundle\Entity\Product".
Every Entity must have an identifier/primary key.

даже если таблица не существует ..


Спасибо за помощь

3

Решение

Если вы преобразовали свои сопоставления в аннотации из xml / yml, обязательно удалите старые файлы сопоставлений.

В этом примере работает: php app/console doctrine:mapping:convert annotation

преобразовать: AppBundle\Resources\config\doctrine\MyEntity.doctrine.xml

в аннотации, встроенные в этот файл: AppBundle\Entity\MyEntity.php

выдается ошибка, потому что он использует сопоставления XML, прежде чем он использует аннотации.
Удалить XML и должно быть хорошо.

3

Другие решения

Если вы внесли изменения в класс сущностей, вы также должны очистить кэш Doctrine:

php app/console doctrine:cache:clear-metadata && app/console doctrine:cache:clear-query && app/console doctrine:cache:clear-result
0

В вашем проекте проверка сущности Product определяется как пример (с комментарием @ORM …)

попробуй сбросить таблицу продут тоже когда сделаешь новый тест

// src/AppBundle/Entity/Product.php
namespace AppBundle\Entity;

use Doctrine\ORM\Mapping as ORM;

/**
* @ORM\Entity
* @ORM\Table(name="product")
*/
class Product
{
/**
* @ORM\Column(type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
protected $id;

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

/**
* @ORM\Column(type="decimal", scale=2)
*/
protected $price;

/**
* @ORM\Column(type="text")
*/
protected $description;
}
0

да, мой продукт точно такой же, как вы сообщили

namespace MyBundle\Entity;

use Doctrine\ORM\Mapping as ORM;

/**
* @ORM\Entity
* @ORM\Table(name="product")
*/
class Product
{
/**
* @ORM\Column(type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
protected $id;

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

/**
* @ORM\Column(type="decimal", scale=2)
*/
protected $price;

/**
* @ORM\Column(type="text")
*/
protected $description;
}
0
По вопросам рекламы [email protected]