1. 程式人生 > >mysql把一個表某個欄位的內容複製到另一張表的某個欄位的SQL語句寫法

mysql把一個表某個欄位的內容複製到另一張表的某個欄位的SQL語句寫法

需求:把一個表某個欄位內容複製到另一張表的某個欄位。
實現sql語句1:

UPDATE file_manager_folder f1
LEFT OUTER JOIN file_manager_folder f2 
    ON f1.name = f2.name AND f2.parentId = 54
SET f1.parentId = 54 
WHERE f2.name IS NULL AND f1.id IN (1,2,3);

實現sql語句2:

update B set extra = A.extra from A join B on (A.id = B.id);

實現sql語句3:

update b set b.sms = (select a.sms from a where a.id = b.id)

需要確定兩張表中的id都是主鍵或者唯一

實現sql語句4:

UPDATE A SET A.SMS = (SELECT B.SMS FROM B WHERE A.ID = B.ID) WHERE EXISTS (SELECT 1 FROM B WHERE A.ID = B.ID);

實現sql語句5:
複製一個表字段資料到另外一個表的欄位,可以這麼寫:
實現sql語句5:

UPDATE tb_1 INNER JOIN tb_2 ON tb_1.tid = tb_2.tid
SET
tb_1.tcontent = tb_2.tcontent

附:同表複製

需求:把同一張表的一個欄位內的內容複製到另一個欄位裡

例1:
我想把article表中A欄位的內容複製到article表中B欄位裡面sql語句為:

update article set B=A;

例2:
有時候,我們需要複製某個欄位一整列的資料到另外一個新的欄位中,這很簡單,SQL可以這麼寫:

UPDATE tb_1 SET content_target = content_source;

大概寫法如下:

Update {your_table} set {source_field} = {object_field}
WHERE cause