Hologres INSERT ON CONFLICT

本文介绍了Hologres中的INSERT ON CONFLICT语法,用于在主键冲突时更新或跳过操作。该语法适用于SQL数据导入,要求条件包含所有主键。当遇到错误‘duplicate key value violates unique constraint’时,可能是因为数据源包含重复数据,可以通过配置参数来选择保留第一条或最后一条重复数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

INSERT ON CONFLICT

现有一个业务需求:需要根据关联关系,用B表的数据修改A表中的一个字段。

当看到这个需求的时候,我首先想到的是常用的DB中那种UPDATE...JOIN...的语法。

但是经过测试,发现Hologres不支持MySQL那种UPDATE...JOIN...的语法,所以只能去查询文档,发现Hologres支持INSERT ON CONFLICT语法,可以实现类似的功能。

INSERT ON CONFLICT语句用于在指定列插入某行数据时,如果主键存在重复的行数据,则对该数据执行更新或跳过操作。

使用限制

  • INSERT ON CONFLICT语句的条件必须包含所有主键。

  • 如果系统提示实例版本过低不支持该功能。您可以执行如下命令或提交工单升级实例至最新版本。

    set hg_experimental_enable_insert_on_conflict = on; 
    

应用场景

INSERT ON CONFLICT命令适用于通过SQL方式导入数据的场景。

命令格式

INSERT ON CONFLICT的语法格式如下。

INSERT INTO table_name [ AS alias ] [ ( column_name [, ...] ) ]
    {  VALUES ( { expression } [, ...] ) [, ...] | query }
    [ ON CONFLICT [ conflict_target ] conflict_action ]

where conflict_target is pk

    ON CONSTRAINT constraint_name

and conflict_action is one of:

    DO NOTHING
    DO UPDATE SET { column_name = { expression } |
                    ( column_name [, .
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值