无法在Symfony中创建索引列

时间:2018-12-12 10:59:51

标签: php mysql symfony doctrine-orm

我以前创建了一个包含多列的表。其中有一个longtext类型的“邮件” 列。我想通过为"message"列创建索引来修改表。我更改了实体,并在bash上用午餐命令更新了表。不幸的是,我收到了此错误消息。

An exception occurred while executing 'CREATE INDEX message_idx ON 
project (message)':SQLSTATE[42000]: Syntax error or access violation: 
1170 BLOB/TEXT column 'message' used in key specification without a key 
length      

我想指出的是,我一直在寻找进行这种操作的方法。这就是我在我这边所做的。

索引:

 * @ORM\Table(indexes={@ORM\Index(name="message_idx",columns={"message"},options={"length"=255})})

列:

 /**
 * @var String $message
 * @ORM\Column(name="message", type="text",length=255,nullable=true,options={"default": "NULL"})
 */
private $message;

1 个答案:

答案 0 :(得分:2)

尝试

/**
 * @ORM\Entity
 * @ORM\Table(indexes={@ORM\Index(name="message_idx",columns={"message"}, options={"length": 255})})
 */
class Test
{
    /**
     * @var int
     *
     * @ORM\Column(name="id", type="integer", nullable=false)
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="AUTO")
     */
    private $id;

    /**
    * @ORM\Column(name="message", type="string", length=255,nullable=true)
    */
    private $message;

}

当您使用文本类型作为索引时,您需要定义一个长度,而“文本”类型没有长度,因此您需要使用“字符串”和长度

enter image description here