簡體   English   中英

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

[英]Is it possible to add a autoincrement primary index column in full mysql table belated?

假設這個表有近 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

是否可以添加具有autoincrement的主索引列id作為第一位? 我期待這樣的事情:

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

這可能嗎?

編輯:我應該提到,我希望填充添加的列。

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

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

有關更多信息,請參閱ALTER TABLE 的 MySQL 文檔

使用您想要的結構和自動遞增鍵創建一個新表,然后將該表中的所有記錄插入到該新表中......然后刪除(或重命名)原始表,並將新表重命名為原名。

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

然后 newTable 將包含您想要的 output。

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;

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM