Intereting Posts
.htaccess файл: динамическое перенаправление PHP, получение переменной из другого php-файла Скрипт php sorter выводит только те же данные, хотя я прошу его делать разные DOMDocument добавляет уже исправленный html из строки Yii: Формирование dataProvider в CGridView Добавление класса css к определенным элементам активного контрольного списка Yii Почему в ячейке используется левая и верхняя набивка с использованием TCPDF в php? Внедрение пакета PHP / Unpack в несоответствие Javascript Получение действия контроллера до того, как код поведения будет запущен в Yii2 Проблема ответа формы бюллетеня AMP выберите *, который соответствует почтовому индексу пользователя в таблице mysql? Контактная форма отправляет почту с пустым полем сообщения Снимок экрана с div с html2canvas. Отправлено в php, сохранено: поврежденное изображение Fileinfo возвращает другой тип mimetype в версии PHP версии 5.4.22 и 5.3.3 Значения по умолчанию MySQL не работают должным образом

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

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

Я скопировал точный пример: я успешно создал базу данных и создал таблицу 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, за исключением имени 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
  • Удалить и воссоздать всю базу данных
  • Удалите объект продукта, очистите кеш и заново создайте все (вручную)
  • Обновление всех поставщиков
  • Проверено все двойные ** для аннотаций
  • Измените компьютер с той же архитектурой программного обеспечения
  • Я также выполнил (спасибо @Srdjan) php app / console doctrine: cache: clear-metadata && app / console doctrine: cache: clear-query && app / console doctrine: cache: clear-result, но getters и seters не генерируются
  • Я удалил таблицу, базу данных и воссоздал шаг за шагом (спасибо @paistra)
  • Я попытался удалить таблицу с помощью

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

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

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

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


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

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

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

В этом примере выполняется: php app/console doctrine:mapping:convert annotation

для преобразования: AppBundle\Resources\config\doctrine\MyEntity.doctrine.xml

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

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

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

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

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

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

 // 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; } 

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

 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; }