--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
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。