MySQL查詢結果復制到新表(更新、插入)


  MySQL中可以將查詢結果復制到另外的一張表中,復制的話通常有兩種情況,一種是更新已有的數據,另一種是插入一條新記錄。下面通過例子來說明。首先構建兩個測試表。

表t1:

表t2:

 

1、如果t2表中存在score值,將score更新到t1表中。方法如下:

UPDATE t1,t2
SET t1.score = t2.score 
WHERE t1.id = t2.id AND t2.score IS NOT NULL

這就是將查詢結果作為條件更新另一張表,當然,t2也可以是更為復雜的一個查詢結果而不是一個具體的表。

 

2、將t1表的username更新至t2表,將t2表的score更新至t1表。方法如下:

UPDATE t1,t2
SET t1.score = t2.score,t2.username = t1.username
WHERE t1.id = t2.id

這個方法其實跟上面的方法類似,可以同時更新兩個表的數據,即做表部分數據的互相復制、更新。

 

3、將t2表的查詢結果插入到t1表中。方法如下:

INSERT INTO t1(id,username,score)
SELECT t2.id,t2.username,t2.score FROM t2 where t2.username = 'lucy'

前面兩種方式是更新表的記錄,這種方式是插入一條新的記錄。其實,從腳本可以看出,這個方法就是將查詢和插入兩個步驟合二為一。

 


免責聲明!

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



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