在实际应用中,经常碰到导入数据的功能,当导入的数据不存在时则进行添加,有修改时则进行更新,
在刚碰到的时候,第一反应是将其实现分为两块,分别是判断增加,判断更新,后来发现在mysql中有
ON DUPLICATE KEY UPDATE一步就可以完成,感觉实在是太方便了。
但是ON DUPLICATE KEY UPDATE为Mysql特有语法,这是个坑
语句的作用,当insert已经存在的记录时,执行Update
在mybatis中进行批量增加或修改的sql为:
<insert id="insertBatch" parameterType="java.util.List">
insert into tabalname(
doctor_id,
total_given_num,
used_num,
avilable_sms_num,
delete_flag,
created_id,
created_time,
modified_id,
modified_time
)
values
<foreach collection="list" item="item" index="index" separator=",