Проблема Doctrine ORM: [Семантическая ошибка] Аннотация не существует или не может быть загружена автоматически

Проблема, с которой я сталкиваюсь на данный момент.

Error Encounter: [Semantical Error] The annotation "@Doctrine\ORM\Mapping\Id_users" in property Users\Entity\User::$id_users does not exist, or could not be auto-loaded.

Мой PHP-код сущности:

<?php

declare(strict_types=1);

namespace Users\Entity;

use Doctrine\ORM\Mapping as ORM;


/**
 * http://www.doctrine-project.org/projects/doctrine-orm/en/2.6/reference/basic-mapping.html
 * @ORM\Entity
 * @ORM\Table(name="users")
 */

class User
{
    /**
     * @ORM\Id_users
     * @ORM\Column(type="integer", name="id_users", nullable=false)
     * @ORM\GeneratedValue(strategy="IDENTITY")
     */
    protected $id_users;

    /**
     * @ORM\Username
     * @ORM\Column(type="varchar", name="username", nullable=false)
     */
    protected $username;

    /**
     * @ORM\Password
     * @ORM\Column(type="varchar", name="password", nullable=false)
     */
    protected $password;

    /**
     * @ORM\Email
     * @ORM\Column(type="varchar", name="email", nullable=false)
     */
    protected $email;

    /**
     * @ORM\Status
     * @ORM\Column(type="integer", name="status", nullable=false)
     */
    protected $status;

    /**
     * @ORM\Date_created
     * @ORM\Column(type="datetime", name="date_created", nullable=false)
     */
    protected $date_created;

    /**
     * @ORM\Date_updated
     * @ORM\Column(type="datetime", name="date_updated", nullable=true)
     */
    protected $date_updated;

    /**
     * @return int
     */
    public function getIdUsers()
    {
        return $this->id_users;
    }

    /**
     * @param int $id_users
     */
    public function setIdUsers($id_users): void
    {
        $this->id_users = $id_users;
    }



    /**
     * @return mixed
     */
    public function getUsername()
    {
        return $this->username;
    }

    /**
     * @param mixed $username
     */
    public function setUsername($username): void
    {
        $this->username = $username;
    }

    /**
     * @return mixed
     */
    public function getPassword()
    {
        return $this->password;
    }

    /**
     * @param mixed $password
     */
    public function setPassword($password): void
    {
        $this->password = $password;
    }

    /**
     * @return mixed
     */
    public function getEmail()
    {
        return $this->email;
    }

    /**
     * @param mixed $email
     */
    public function setEmail($email): void
    {
        $this->email = $email;
    }

    /**
     * @return mixed
     */
    public function getStatus()
    {
        return $this->status;
    }

    /**
     * @param mixed $status
     */
    public function setStatus($status): void
    {
        $this->status = $status;
    }

    /**
     * @return \DateTime
     */
    public function getDateCreated(): \DateTime
    {
        return $this->date_created;
    }

    /**
     * @param \DateTime $date_created
     * @throws \Exception
     */
    public function setDateCreated(\DateTime $date_created = null): void
    {
        if (!$date_created && empty($this->getIdUser())) {
            $this->date_created = new \DateTime("now");
        } else {
            $this->date_created = $date_created;
        }
    }

    /**
     * @return \DateTime
     */
    public function getDateUpdated(): \DateTime
    {
        return $this->date_updated;
    }

    /**
     * @param \DateTime $date_updated
     * @throws \Exception
     */
    public function setDateUpdated(\DateTime $date_updated = null): void
    {
        if ($date_updated) {
            $this->date_updated = new \DateTime("now");
        } else {
            $this->date_updated = $date_updated;
        }
    }



}

Вот фрагмент моего фрагмента поставщика конфигурации:

    public function getDoctrineEntities() : array
    {
        return [
            'driver' => [
                'orm_default' => [
                    'class' => MappingDriverChain::class,
                    'drivers' => [
                        'Users\Entity' => 'user_entity',
                    ],
                ],
                'user_entity' => [
                    'class' => AnnotationDriver::class,
                    'cache' => 'array',
                    'paths' => [__DIR__ . '/Entity'],
                ]
            ]
        ];
    }

Я уже пытался переименовать обновление своих меток и переменных, но не могу устранить эту проблему. Есть ли конфигурация, которую я пропустил? Я использую последнюю версию Zend Expressive. Любые предложения и комментарии будут оценены.


person tom_cruz    schedule 26.07.2019    source источник


Ответы (2)


Аннотация @ORM\Id_users недействительна. Правильная аннотация для поля id — @ORM\Id. Оно не связано с именем свойства, но указывает, что свойство является первичным ключом.

Аннотированная переменная экземпляра будет помечена как идентификатор объекта, первичный ключ в базе данных. Эта аннотация является только маркером и не имеет обязательных или необязательных атрибутов. Для сущностей с несколькими столбцами идентификаторов каждый столбец должен быть помечен @Id.

Как говорит Flying, вы должны удалить @ORM\{property name} для всех остальных свойств. Полный список допустимых аннотаций можно найти в доктрина ocs.

person xtreamwayz    schedule 27.07.2019

В Doctrine действительно нет таких аннотаций.

Вам нужно удалить все аннотации, похожие на @ORM\{column name}, из вашего курса.

Например, тот, что Doctrine упоминается в сообщении об ошибке @ORM\Id_users, принадлежащем свойству $id_users. Если вы удалите его - Doctrine сообщит об ошибке следующего @ORM\Username и так далее.

person Flying    schedule 27.07.2019