merge into 要修改的表名 别名1
using (select 要修改的字段值,要修改的字段值, 要修改的字段值 from 表名) 别名2
on (别名1.关联字段 = 别名2. 关联字段)
when matched then update set
别名1.字段 = 别名2.字段
别名1.字段 = 别名2.字段
<!-- 批量添加 -->
<insert id="batchAdd" parameterType="java.util.List">
merge into t_tabe_temp fail
using
(
<foreach collection="list" item="item" separator="union all"> <!-- 传入的集合参数值 -->
select
#{item.id, jdbcType=VARCHAR} id,
#{item.time, jdbcType=VARCHAR} time,
from dual
</foreach>
) t1
on (fail.id= t1.id) <!-- 关联的主键编号-->
when matched then <!-- 如果存在就更新 -->
update set <!-- 注意,这里不要写set id == xx -->
fail.time = t1.time,
when not matched then <!-- 不存在就插入数据 -->
insert
(fail.id, fail.time)
values
(t1.id, t1.time)
</insert>