MySQL查询结果复制到新表(更新、插入)
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'
前面兩種方式是更新表的記錄,這種方式是插入一條新的記錄。其實,從腳本可以看出,這個方法就是將查詢和插入兩個步驟合二為一。
?
轉載于:https://www.cnblogs.com/super-chao/p/8383601.html
總結
以上是生活随笔為你收集整理的MySQL查询结果复制到新表(更新、插入)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: BZOJ1084 SCOI2005最大子
- 下一篇: 【ubuntu】安装之后要安装的一些东西