Doctrine orm 条令ORM问题:[语义错误]批注不存在,或无法自动加载
我目前遇到的问题Doctrine orm 条令ORM问题:[语义错误]批注不存在,或无法自动加载,doctrine-orm,mezzio,Doctrine Orm,Mezzio,我目前遇到的问题 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;
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;
}
}
}
我已经尝试过重命名更新我的标签和变量,但我似乎无法消除这个问题。是否有我遗漏的配置?我正在使用Zend Expressive的最新版本。任何建议和评论都将不胜感激。理论中确实没有此类注释 您需要从类中删除所有看起来像
@ORM\{column name}
的注释
例如,在属于
$Id\u users
属性的错误消息@ORM\Id\u users
中提到了一个原则。如果您要删除它-条令将报告下一个的错误@ORM\Username
等等。注释@ORM\Id\u users
无效。id字段的正确注释是@ORM\id
。它与属性的名称无关,但用于指示属性是主键
带注释的实例变量将标记为实体标识符,即数据库中的主键。此注释仅为标记,没有必需或可选属性。对于具有多个标识符列的实体,每列都必须用@Id标记
正如Flying所说,您应该删除所有其他属性的@ORM\{property name}
。可以在中找到有效批注的完整列表
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'],
]
]
];
}