2

我有下表:

mysql> show create table keyword_links\G
*************************** 1. row ***************************
       Table: keyword_links
Create Table: CREATE TABLE `keyword_links` (
  `keyword_id` int(11) NOT NULL AUTO_INCREMENT,
  `keyword` tinytext NOT NULL,
  `link` tinytext,
  `weight` smallint(6) NOT NULL DEFAULT '0',
  `class_id` smallint(6) NOT NULL DEFAULT '0',
  `category_id` smallint(6) NOT NULL DEFAULT '0',
  `timestamp` timestamp NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  PRIMARY KEY (`keyword_id`),
  KEY `class_id` (`class_id`),
  KEY `category_id` (`category_id`),
  KEY `idx_keyword` (`keyword`(333))
) ENGINE=MyISAM AUTO_INCREMENT=5082 DEFAULT CHARSET=utf8

我正在尝试向其中添加一个新列,但失败了:

mysql> ALTER TABLE keyword_links ADD COLUMN list_id INT UNSIGNED NOT NULL DEFAULT 0;
ERROR 1170 (42000): BLOB/TEXT column 'keyword' used in key specification without a key length

列上的索引keyword确实具有 333 的键长度,那么为什么它会失败以及如何修复它?

更新

我尝试将列上的索引大小keyword从 333 减小到 255,现在我可以成功添加新列:

ALTER TABLE keyword_links DROP INDEX idx_keyword;
CREATE INDEX index_keyword ON keyword_links (keyword(255));
ALTER TABLE keyword_links ADD COLUMN list_id INT UNSIGNED NOT NULL DEFAULT 0;

但我还是想知道发生了什么。

4

2 回答 2

0

我假设索引键只允许 255 个。

于 2013-02-15T23:30:01.213 回答
0

这是因为 myisam 的索引长度限制为 1000 字节(请参阅此链接

请注意,这都是关于字节的,一个字符可能需要 2、3 甚至 4 个字节,具体取决于您的编码,并且 INT将始终为 4 个字节

于 2013-02-15T23:38:42.753 回答