Mysql數(shù)據(jù)庫中復(fù)制表的操作是非常常見的一種,因?yàn)橛袝r(shí)候需要將某張表的數(shù)據(jù)結(jié)構(gòu)和數(shù)據(jù)完全復(fù)制到另外一張表當(dāng)中。下面我們就介紹一下如何在Mysql中新建復(fù)制一張表。
首先,我們需要使用CREATE TABLE語句來新建一張表。
CREATE TABLE new_table_name (
column1_name column1_definition,
column2_name column2_definition,
...
);
其中,new_table_name為新建表的表名,column1_name和column2_name為新表所需的列名,column1_definition和column2_definition則為對(duì)應(yīng)列的定義。例如:
CREATE TABLE new_table (
id INT(10) UNSIGNED NOT NULL AUTO_INCREMENT,
name VARCHAR(20) NOT NULL,
age INT(3) NOT NULL,
address VARCHAR(50) DEFAULT NULL,
PRIMARY KEY (id)
);
這個(gè)例子中,我們新建了一張名為new_table的表,該表包含4個(gè)列分別為id、name、age和address。其中,id為自動(dòng)增長(zhǎng)的數(shù)字類型,不能為NULL,name為長(zhǎng)度不超過20個(gè)字符的字符串類型,不能為NULL,age為不超過3位數(shù)的數(shù)字類型,不能為NULL,address為長(zhǎng)度不超過50個(gè)字符的字符串類型,可為NULL。PRIMARY KEY設(shè)置id為主鍵。
接下來,我們需要使用INSERT INTO語句將原有表中的數(shù)據(jù)完全復(fù)制到新表中。
INSERT INTO new_table (column1, column2, column3, ...)
SELECT old_column1, old_column2, old_column3, ...
FROM old_table_name;
其中,new_table為新建表的表名,column1、column2、column3為空表中的列名,old_table_name為原有表的表名,old_column1、old_column2、old_column3則為原有表中的列名。例如:
INSERT INTO new_table (name, age, address)
SELECT name, age, address
FROM old_table;
這個(gè)例子中,我們將原有表old_table中的name、age和address列的數(shù)據(jù)復(fù)制到了新表new_table中的對(duì)應(yīng)列。
這樣,我們就完成了Mysql中新建復(fù)制一張表的操作。