参考代码
select * from TEST_A099select * from TEST_A099_COPYUPDATE TEST_A099 AA
SET (NAME,ADDRESS) = (SELECT NAME,ADDRESS FROM TEST_A099_COPY BB WHERE BB.ID = AA.ID)WHERE EXISTS (SELECT * FROM TEST_A099_COPY BB WHERE BB.ID = AA.ID);
执行逻辑解析
结论: 关键字不加会将匹配不到的数据重置为null(非常危险),一般必须加除非保证完全匹配;
待更新表可以多对一 数据源表不能一对多(会报错) 只能一条数据 可以加rownum解决(有问题)
参考文献
Oracle多表关联更新(update多表关联)_oracle_立志转型的通讯狗-华为云开发者联盟 (csdn.net)
UPDATE TEST_A099 AA
SET (NAME,ADDRESS) = (SELECT NAME,ADDRESS FROM TEST_A099_COPY BB WHERE BB.ID = AA.ID and rownum=1)WHERE EXISTS (SELECT * FROM TEST_A099_COPY BB WHERE BB.ID = AA.ID);