加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

postgresql upsert 使用范例

发布时间:2020-12-13 17:02:11 所属栏目:百科 来源:网络整理
导读:--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) co
--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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读