PgSQL upsert批量查询插入或更新(insert select/on conflict do update踩坑记录)

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>
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值