我以前创建了一个包含多列的表。其中有一个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;
答案 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;
}
当您使用文本类型作为索引时,您需要定义一个长度,而“文本”类型没有长度,因此您需要使用“字符串”和长度