MySQL中複製資料表中的資料到新表中的操作教程

choubou發表於2021-09-09

MySQL是不支援SELECT … INTO語法的,使用INSERT INTO … SELECT替代相同用法,下面我們我們這裡簡答分一下新表存在和不存在兩種情況,具體使用不同的語句。
1.新表不存在
複製表結構即資料到新表

?

12 create table new_tableselect * from old_talbe;

這種方法會將old_table中所有的內容都複製過來,用這種方法需要注意,new_table中沒有了old_table中的primary key,Extra,auto_increment等屬性,需要自己手動加,具體參看後面的修改表即欄位屬性.
只複製表結構到新表

?

123456 # 第一種方法,和上面類似,只是資料記錄為空,即給一個false條件create table new_tableselect * from old_table where 1=2; # 第二種方法create table new_table like old_table;

2.新表存在
複製舊錶資料到新表(假設兩個表結構一樣)

?

12 insert into new_tableselect * from old_table;

複製舊錶資料到新表(假設兩個表結構不一樣)

?

12 insert into new_table(field1,field2,.....)select field1,field2,field3 from old_table;

複製全部資料

?

1 select * into new_table from old_table;

只複製表結構到新表

?

1 select * into new_talble from old_table where 1=2;

3.例項

(1)表不存在複製

?


mysql>show tables; +-----------------+ |Tables_in_test1 | +-----------------+ |cpu_stat    | |test1      | |test2      | |test3      | +-----------------+ 4rows in set (0.02 sec)   mysql> create tabletest4 as select * from test1 where 1=0;  //僅複製表結構 QueryOK, 0 rows affected (0.06 sec) Records:0 Duplicates: 0 Warnings: 0   mysql> create tabletest5 as select * from test1;  //把表test1所有內容複製為test5 QueryOK, 7 rows affected (0.11 sec) Records:7 Duplicates: 0 Warnings: 0

 
(2)表已經存在複製

?


mysql> create table test6(id int not null auto_increment primary key, name varchar(20)); Query OK, 0 rows affected (0.13 sec)   mysql> insert into test6(name) select name from test1; //只複製nameQuery OK, 7 rows affected (0.06 sec) Records: 7 Duplicates: 0 Warnings: 0   mysql> select * from test6; +----+-------+ | id | name | +----+-------+ | 1 | wu  | | 2 | terry | | 3 | tang | …… 7 rows in set (0.00 sec)

 

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/4548/viewspace-2805874/,如需轉載,請註明出處,否則將追究法律責任。

相關文章