MySQL中快速復制數據表方法匯總


本文將着重介紹兩個MySQL命令的組合,它將以原有數據表為基礎,創建相同結構和數據的新數據表。

這可以幫助你在開發過程中快速的復制表格作為測試數據,而不必冒險直接操作正在運行 的數據表。

示例如下:

將 production 數據庫中的 mytbl 表快速復制為 mytbl_new,2個命令如下:


CREATE TABLE mytbl_new LIKE production.mytbl;

INSERT mytbl_new SELECT * FROM production.mytbl;


第一個命令是創建新的數據表 mytbl_new ,並復制 mytbl 的數據表結構。

第二個命令是講數據表 mytbl 中的數據復制到新表 mytbl_new 。


注:production.mytbl是指定要復制表的數據庫名稱為 production 。它是可選的。

假如沒有production. ,MySQL數據庫將會假設mytbl在當前操作的數據庫。

其它方法:
方案1:
復制整個表 
CREATE TABLE new_table SELECT * FROM old_table;

復制,不復制數據 
CREATE TABLE new_table SELECT * FROM old_table where 0;

注意:本方案其實只是把select語句的結果建一個表。所以new_table這個表不會有主鍵、索引。

方案2:
假如我們有以下這樣一個表:

id      username    password


1. 下面這個語句會拷貝表結構到新表newadmin中。 (不會拷貝表中的數據)

CREATE TABLE newadmin LIKE admin

2. 下面這個語句會拷貝數據到新表中。 注意:這個語句其實只是把select語句的結果建一個表。所以newadmin這個 表不會有主鍵,索引。


CREATE TABLE newadmin AS 

SELECT * 
FROM admin 
)

3. 如果你要真正的復制一個表。可以用下面的語句。

CREATE TABLE newadmin LIKE admin; 
INSERT INTO newadmin SELECT * FROM admin;

4. 我們可以操作不同的數據庫。

CREATE TABLE newadmin LIKE shop.admin; 
CREATE TABLE newshop.newadmin LIKE shop.admin;

5. 我們也可以拷貝一個表中其中的一些字段。

CREATE TABLE newadmin AS 

SELECT username, password FROM admin 
)

6. 我們也可以講新建的表的字段改名。

CREATE TABLE newadmin AS 

SELECT id, username AS uname, password AS pass FROM admin 
)

7. 我們也可以拷貝一部分數據。

CREATE TABLE newadmin AS 

SELECT * FROM admin WHERE LEFT(username,1) = 's' 
)

8. 我們也可以在創建表的同時定義表中的字段信息。

CREATE TABLE newadmin 

id INTEGER NOT NULL AUTO_INCREMENT PRIMARY KEY 

AS 

SELECT * FROM admin 
)


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM