通过 mySQL 转储导入 Joomla 1.5 数据库但出现错误“1071 - 指定的 key 太长;最大 key 长度为 1000 字节”
罪魁祸首的sql语句是:
CREATE TABLE `jos_core_acl_aro` (
`id` INT( 11 ) NOT NULL AUTO_INCREMENT ,
`section_value` VARCHAR( 240 ) NOT NULL DEFAULT '0',
`value` VARCHAR( 240 ) NOT NULL ,
`order_value` INT( 11 ) NOT NULL DEFAULT '0',
`name` VARCHAR( 255 ) NOT NULL ,
`hidden` INT( 11 ) NOT NULL DEFAULT '0',
PRIMARY KEY ( `id` ) ,
UNIQUE KEY ( `section_value` , `value` ) ,
KEY `jos_gacl_hidden_aro` ( `hidden` )
) ENGINE = MYISAM DEFAULT CHARSET = utf8 AUTO_INCREMENT =11;
MySQL said:
#1071 - Specified key was too long; max key length is 1000 bytes
源和目标数据库是 UTF8。我仍然不知道为什么会出现此错误:(
最佳答案
mysql 将 utf8 编码的字符存储为 3 个字节
你的 key
UNIQUE KEY ( `section_value` , `value` ) ,
大小为 (240 + 240) * 3 字节,大于 1000 个限制
关于mysql - 指定的 key 太长;最大 key 长度为 1000 字节,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6157823/