SQL把一個表中數據更新到另一個表的多種方法


在此僅記下SQL從一個表中把數據簡單地更新到另一個表的多種方法, 由於水平有限,如有不妥之處請高手指正:)

SQL 從A表取數據更新到B表 的多種方法:

假設有二個表, 分別為:T1, T2

先創建二個表,創建T1 如下代碼:

CREATE TABLE T1
(
    A NVARCHAR(10),
    B NVARCHAR(10),
    DC NVARCHAR(100),
    AId int identity(10000,1) primary key
)

CREATE TABLE T2
(
    A1 NVARCHAR(10),
    B1 NVARCHAR(10),
    DC1 NVARCHAR(100),
    aId1 int identity(100,1) primary key
)

 插入測試數據:

向T1表中插入測試數據:
INSERT INTO T1 select 'A1','B01','一年后'
INSERT INTO T1 select 'AA1','B001','二年后'

再向T2表中插入測試數據:

INSERT INTO T2 select 'A1','B01','一月后'
INSERT INTO T2 select 'AA1','BB001','二月后'

現在我們需要把T1表中的DC字段更新為T2表中DC1的值,條件為T1中的A字段的值等於T2表中的A1字段的值且T1表中的B字段的值等於T2表中B2字段的值(這樣寫主要是因為表和表之間的關聯關系可能有多個字段,此處只選二個字段,多個依此類推)。

方法一:可以根據查出的值一條一條更新去執行SQL更新.或手動更新也可以,此處不討論這種方法,略過.

方法二:可以通過一條SQL語句一次更新多條數據.SQL語句寫法略有不同,如下:

A): 方法

Update T1
set dc=(select dc1 from t2 where T1.A=T2.A1 AND T1.B=T2.B1)
WHERE T1.AID in (
    SELECT AID FROM T1
    INNER JOIN T2 ON t1.A=T2.A1 AND T1.B=T2.B1
)
注:在我標我紅色的in地方如果把'in'換成'='將出錯,但在下面的B種寫法里就可以換成'=',變成C方法寫法.


B): 方法

Update T1
set dc=(select dc1 from t2 where T1.A=T2.A1 AND T1.B=T2.B1)
WHERE T1.AID in (
    SELECT T1.AID FROM T2
    WHERE t1.A=T2.A1 AND T1.B=T2.B1
)

C): 方法

Update T1
set dc=(select dc1 from t2 where T1.A=T2.A1 AND T1.B=T2.B1)
WHERE T1.AID = (
    SELECT T1.AID FROM T2
    WHERE t1.A=T2.A1 AND T1.B=T2.B1
)

 D): 方法

Update T1
set dc=(select dc1 from T2 where T1.A=T2.A1 AND T1.B=T2.B1)
WHERE T1.A = (
    SELECT T1.A FROM T2
    WHERE T1.A=T2.A1 AND T1.B=T2.B1
)

E):方法

Update T1
set dc=(select dc1 from T2 where T1.A=T2.A1 AND T1.B=T2.B1)
WHERE T1.A = (
    SELECT T2.A1 FROM T2
    WHERE T1.A=T2.A1 AND T1.B=T2.B1
)

F): 方法 

Update T1
set dc=(select dc1 from T2 where T1.A=T2.A1 AND T1.B=T2.B1)
WHERE T1.A in (
    SELECT T2.A1 FROM T2
    WHERE T1.A=T2.A1 AND T1.B=T2.B1
)

 注:如果在F)方法改寫成如下的寫法將會出錯。

Update T1
set dc=(select dc1 from T2 where T1.A=T2.A1 AND T1.B=T2.B1)
WHERE T1.A in (
    SELECT T1.A FROM T1
    INNER JOIN T2 ON t1.A=T2.A1 AND T1.B=T2.B1
)

 此種方法將會更新掉所有符合T1.A in ()這個條件的數據,所以是不正確的, 所以不能這樣寫。

G):方法

Update T1
set dc=(select dc1 from T2 where T1.A=T2.A1 AND T1.B=T2.B1 AND T1.DC=T2.DC1)
FROM T1, T2
WHERE  T1.A=T2.A1 AND T1.B=T2.B1

H):方法

Update T1
set T1.dc=T2.dc1
FROM T1
INNER JOIN T2 ON T1.A=T2.A1 AND T1.B=T2.B1
WHERE t1.A=T2.A1 AND T1.B=T2.B1

  注:此處我用灰色標記的部分可以去掉。

I): 方法

Update T1
set T1.dc=T2.dc1
FROM T1, T2
WHERE  T1.A=T2.A1 AND T1.B=T2.B1

請特別注意以上方法中我用紅色標記上的代碼寫法。

總節:雖然是一條簡單的更新語名但也有多種寫法,且每種寫法各有優缺點。

大家是否還有更簡單的寫法或者更容易理解的寫法?如果有請提出來一起討論,謝謝!

說明測試環境:以上代碼在MSSQL2005中驗證是可行的.

 


免責聲明!

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



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