3

我正在使用 Zend 2 框架,我正在尝试使用 Doctrine 2 获取数据。

但是,实体文件中出现以下错误。

教义\ORM\映射\映射异常

没有为实体“Acl\Entity\Permission”指定标识符/主键。每个实体都必须有一个标识符/主键。

如何指定主键?

我正在使用以下代码。

/**
 * User Permissions
 *
 * @ORM\Entity
 * @ORM\Table(name="acl_permissions")
 * @property int $id
 * @property int $role_id
 * @property int $resource_id
 * @property string $action
 */
class Permission
{
    /**
     * @ORM\Column(type="integer")
     */
    public $id;

    /**
     * @ORM\Column(type="integer")
     * @ORM\OneToOne(targetEntity="Role")
     * @ORM\JoinColumn(name="role_id", referencedColumnName="id")
     */
    public $role;

    /**
     * @ORM\Column(type="integer")
     * @ORM\OneToOne(targetEntity="Resource")
     * @ORM\JoinColumn(name="resource_id", referencedColumnName="id")
     */
    public $resource;

    /**
     * @ORM\Column(type="string")
     */
    public $action;

    public function getRole()
    {
    return $this->role;
    }

    public function getResource()
    {
    return $this->resource;
    }
}
4

1 回答 1

7

你检查过文档吗?

您可以使用@ORM\Id注释定义主键。如果值是自动生成的(例如,如果使用auto_increment),您还需要设置@ORM\GeneratedValue(strategy="IDENTITY")注释。

于 2013-01-22T16:04:28.737 回答