PGSQL数据库中根据唯一索引判断存在不存在,存在则更新,不存在就新增,可以参考下的sql,注意其中的item_type,item_type_id,item_group,item_group_key四个字段组成唯一的联合主键,没有这样的联合主键,就会报"there is no unique or exclusion constraint matching the ON CONFLICT specification"错误!
mapper:
long saveAA(@Param("param") CreateConfigParam param);
xml:
<update id="updatePersonInfo" paramterType="com.test.pojo.Person">
insert into person(name,age,hobby,city,school,mobile)
values
(#{name},
#{age},
#{hobby},
#{city},
#{school},
#{mobile}
)
on conflict(mobile,name) do nothing
</update>
<insert id="saveAA" parameterType="com.XX.CreateConfigParam">
INSERT INTO t_config (item_type,item_type_id,item_group,item_group_key,item_group_value,create_at,create_by)
values ( #{param.itemType},#{param.itemTypeId},#{param.itemGroup},#{param.itemGroupKey},#{param.itemGroupValue},#{param.createAt}, #{param.createBy})
on conflict(item_type,item_type_id,item_group,item_group_key) do update set
item_group_value = #{param.itemGroupValue}
</insert>
本文介绍了如何在PostgreSQL中使用唯一索引确保数据的唯一性,通过ON CONFLICT处理策略,既更新已存在的记录,又处理新记录的插入。重点讲解了在`item_type`, `item_type_id`, `item_group`, `item_group_key`联合主键约束下避免冲突的方法。
6847

被折叠的 条评论
为什么被折叠?



