MySQL是一種關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),能夠方便處理數(shù)據(jù)的存儲(chǔ)和檢索,其中表的結(jié)構(gòu)和索引是關(guān)系型數(shù)據(jù)庫(kù)中最基本的部分。在一些場(chǎng)景下,你可能需要復(fù)制一個(gè)表并且保留其原有的索引。MySQL提供了幾種方法,以下介紹其中的一些。
方法一:使用CREATE TABLE ... LIKE ... 從已有的表復(fù)制表結(jié)構(gòu)
CREATE TABLE new_table LIKE existing_table;
以上命令會(huì)創(chuàng)建一個(gè)新表new_table,其結(jié)構(gòu)與已有表existing_table相同。現(xiàn)在你可以向新表中插入記錄了,但不會(huì)包括現(xiàn)有表中的任何記錄。
方法二:使用CREATE TABLE ... SELECT ... 從已有的表復(fù)制結(jié)構(gòu)和數(shù)據(jù)
CREATE TABLE one_table (LIKE existing_table);
INSERT INTO one_table SELECT * FROM existing_table;
同樣的,以上命令會(huì)創(chuàng)建一個(gè)新表one_table,并將已有表existing_table的結(jié)構(gòu)和數(shù)據(jù)拷貝到新表中。
方法三:使用ALTER TABLE ... RENAME 重命名表
ALTER TABLE existing_table RENAME TO new_table;
以上命令會(huì)將已有表existing_table重命名為新表new_table。此方法可以在或不在同一數(shù)據(jù)庫(kù)中使用,也支持進(jìn)行跨庫(kù)的操作。
在使用以上方法復(fù)制表結(jié)構(gòu)時(shí),如果需要保留原有的索引,可以從SHOW INDEXES ... WHERE...語(yǔ)句中得到索引相關(guān)的信息。以下代碼為讀取表existing_table中的索引信息:
SHOW INDEXES FROM existing_table;
索引信息包括索引名稱、關(guān)鍵字(UNIQUE、FULLTEXT等)、字段名稱、排序方式等信息。在合適的時(shí)機(jī)使用CREATE INDEX ... 或其他相關(guān)命令來(lái)為新表創(chuàng)建索引。