1. 程式人生 > 其它 >MySQL中將select結果執行update

MySQL中將select結果執行update

一、單表查詢—>更新

UPDATE table_name
SET field1=new-value1, field2=new-value2
[WHERE Clause]

二、多表聯合查詢—>更新

UPDATE a
INNER JOIN (SELECT yy FROM b) c ON a.id = c.id 
SET a.xx = c.yy
[WHERE Clause]
  • 上面的 INNER JOIN ,可以換為 LEFT JOINRIGHT JOIN 等聯合查詢。
  • SET 後的欄位必須為 a 表中的欄位,該欄位可以等於某個常量,可以等於某一列。若不是 a 表中的欄位,則會報 The target table b of the UPDATE is not updatable
    的資訊。
  • WHERE 子句必須放在 SET 後面
  • UPDATE 後的 a 表不是查詢的結果,也不能是 SELECT 子句

例子:

tableex_copy1表
在這裡插入圖片描述
tablein_copy1表
在這裡插入圖片描述

查詢SQL
SELECT * FROM
tableex_copy1 a LEFT JOIN
(SELECT * FROM tablein_copy1) b
ON a.BID = b.AID
WHERE b.ASEX = '女'
update SQL
UPDATE
#SELECT * FROM
tableex_copy1 a LEFT JOIN
(SELECT * FROM tablein_copy1) b
ON
a.BID = b.AID SET a.CESHI = '6666' WHERE b.ASEX = '女'

更新之後的tableex_copy1表
在這裡插入圖片描述