是否可以在完整的mysql表中添加自动增量主索引列?

时间:2011-05-31 19:39:57

标签: mysql primary-key add

假设这个表有近5 000 000行

CREATE TABLE `author2book` (
  `author_id` int(11) NOT NULL,
  `book_id` int(11) NOT NULL,
  KEY `author_id_INDEX` (`author_id`),
  KEY `paper_id_INDEX` (`book_id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci

是否可以添加id作为首位的主索引列autoincrement?我期待这样的事情:

CREATE TABLE `author2book` (
  `id` int(11) NOT NULL AUTO_INCREMENT,  <<<<  This is what I try to achieve!
  `author_id` int(11) NOT NULL,
  `book_id` int(11) NOT NULL,
  KEY `author_id_INDEX` (`author_id`),
  KEY `paper_id_INDEX` (`book_id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci

这可能吗?

编辑:我应该提一下,我希望填充添加的列。

3 个答案:

答案 0 :(得分:5)

您可以使用ALTER TABLE在一个命令中添加列和索引。即:

ALTER TABLE author2book ADD id INT(11) UNSIGNED NOT NULL AUTO_INCREMENT, ADD PRIMARY KEY (id);

有关详细信息,请参阅MySQL docs for ALTER TABLE

答案 1 :(得分:1)

创建一个包含所需结构的新表和自动递增键,然后将此表中的所有记录插入到该新表中...然后删除(或重命名)原始表,并重命名新表表格为原始名称。

insert into newTable (author_id, book_id) 
select * from author2book
然后

newTable将包含您想要的输出。

答案 2 :(得分:0)

ALTER TABLE author2book
ADD COLUMN `id` int(11) NOT NULL FIRST;

手动填充id字段(可能是脚本?),然后:

ALTER TABLE author2book
MODIFY COLUMN `id` int(11) NOT NULL AUTO_INCREMENT PRIMARY KEY;