Oracle 多表關聯刪除

feelpurple發表於2016-11-18
Oracle 多表關聯刪除,不支援下面的JOIN關聯語法
DELETE FROM TAM_GROUPS_MEMBERS M
JOIN TAM_ABSMEMBER A1 ON M.N_GM_MEMBER_ID=A1.N_ABSMEMBER_ID

JOIN TAM_ABSMEMBER A2 ON M.N_GM_GROUP_ID=A2.N_ABSMEMBER_ID
WHERE A1.C_NAME= ? OR A2.C_NAME= ?;

對於刪除或更新多表關聯,可以使用EXISTS語句改寫上面的SQL
DELETE FROM TAM_GROUPS_MEMBERS M
WHERE EXISTS (SELECT * FROM TAM_ABSMEMBER A1, TAM_ABSMEMBER A2
WHERE M.N_GM_MEMBER_ID=A1.N_ABSMEMBER_ID AND M.N_GM_GROUP_ID=A2.N_ABSMEMBER_ID
AND A1.C_NAME= ? OR A2.C_NAME= ?);

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/26506993/viewspace-2128713/,如需轉載,請註明出處,否則將追究法律責任。

相關文章