postgresql upsert 使用范例

--pg 9.5 版本支持 "UPSERT" 特性, 这个特性支持 INSERT 语句定义 ON CONFLICT DO UPDATE/IGNORE 属性,当插入 SQL 违反约束的情况下定义动作,而不抛出错误

--创建测试数据表
create table t (id int constraint idx_t_id primary key,name varchar(20) constraint cst_name not null);
insert into t values(1,'rudy');
postgres=# select * from t;
 id | name 
----+------
  1 | rudy
(1 row)

--根据字段,当id冲突时更新name值
postgres=# insert into t values(1,'rudy1') ON CONFLICT(id) do update set name=EXCLUDED.name ;
INSERT 0 1
postgres=# select * from t;
 id | name  
----+-------
  1 | rudy1
  

--也可以直接指定约束名,此时不需要字段,在实际应用中,最好使用字段名
postgres=# insert into t values(2,'rudy3') ON CONFLICT ON CONSTRAINT idx_t_id do update set name=EXCLUDED.name ; 
INSERT 0 1
postgres=# select * from t;
 id | name  
----+-------
  1 | rudy1
  2 | rudy3
(2 rows)


--根据where条件选择性更新,由于id没有大于10的数据,故更新0条数据                                                                ^
postgres=# insert into t values(2,'rudy4') ON CONFLICT ON CONSTRAINT idx_t_id do update set name=EXCLUDED.name where t.id>10 ;
INSERT 0 0
postgres=# select * from t;
 id | name  
----+-------
  1 | rudy1
  2 | rudy3
 
--只插入满足条件的数据行 
postgres=# insert into t values(2,'rudy4'),(3,'rudy3') ON CONFLICT(id) do nothing ; 
INSERT 0 1
postgres=# select * from t;
 id | name  
----+-------
  1 | rudy1
  2 | rudy3
  3 | rudy3

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PostgreSQL 中,可以使用以下两种方法来实现 UPSERT(插入或更新)操作: 1. 使用 INSERT ... ON CONFLICT DO UPDATE 语句: 这是 PostgreSQL 9.5 版本引入的一种语法,它允许在插入冲突时执行更新操作。具体的语法如下: ```sql INSERT INTO table_name (column1, column2, ...) VALUES (value1, value2, ...) ON CONFLICT (constraint_name) DO UPDATE SET column1 = value1, column2 = value2, ... ``` 在上述语法中,`table_name` 是要插入数据的表名,`column1, column2, ...` 是要插入的列名,`value1, value2, ...` 是要插入的值。`constraint_name` 是一个唯一约束或主键约束的名称,用于检测冲突。`SET column1 = value1, column2 = value2, ...` 是在冲突时要执行的更新操作。 2. 使用 EXCLUDE 关键字: 这是 PostgreSQL 9.5 版本引入的另一种方法,它使用了唯一约束或排除约束来实现 UPSERT 操作。具体的语法如下: ```sql INSERT INTO table_name (column1, column2, ...) VALUES (value1, value2, ...) ON CONFLICT ON CONSTRAINT constraint_name DO UPDATE SET column1 = value1, column2 = value2, ... ``` 在上述语法中,`table_name` 是要插入数据的表名,`column1, column2, ...` 是要插入的列名,`value1, value2, ...` 是要插入的值。`constraint_name` 是一个唯一约束或排除约束的名称,用于检测冲突。`SET column1 = value1, column2 = value2, ...` 是在冲突时要执行的更新操作。 这两种方法都可以实现在插入数据时,如果存在冲突则执行更新操作,否则执行插入操作。你可以根据具体的需求选择其中一种方法来实现 UPSERT 操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值