在MySQL版本5.6(及更早版本)中,InnoDB表的前缀限制为767个字节。MyISAM表的长度为1,000字节。在MySQL 5.7及更高版本中,此限制已增加到3072字节。
您还必须注意,如果在utf8mb4编码的大char或varchar字段上设置索引,则必须将767字节(或3072字节)的最大索引前缀长度除以4,得到191。这是因为utf8mb4字符的最大长度为四个字节。对于utf8字符,它将是三个字节,导致最大索引前缀长度为254。
您必须采取的一种选择是将下限放在VARCHAR字段上。
另一个选择(根据对此问题的响应)是获取列的子集而不是整个列,即:
ALTER TABLE `mytable` ADD UNIQUE ( column1(15), column2(200) );
进行调整,您需要获取要应用的密钥,但是我想知道是否值得对有关该实体的数据模型进行检查,以查看是否存在可以使您实现预期业务规则而又不违反MySQL限制的改进。



