CitusDB的upsert功能

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

环境

citus62_96(默认安装的postgresql9.6)

$ psql -V
psql (PostgreSQL) 9.6.3

测试

$ sudo -i -u postgres psql

postgres=# create table test(id int,name text,city text);
CREATE TABLE # 创建唯一约束
postgres=# ALTER TABLE test ADD CONSTRAINT name_city UNIQUE (name, city);
ALTER TABLE # 创建以name做hash的分片表
postgres=# select create_distributed_table('test','name');
create_distributed_table
-------------------------- (1 row) postgres=# insert into test values (1,'li','beijing');
INSERT 0 1 postgres=# INSERT INTO test (id, name, city) VALUES (1,'li','shanghai') on CONFLICT (name, city) DO UPDATE SET id = test.id + EXCLUDED.id;
INSERT 0 1 postgres=# select * from test;
id | name | city
----+------+----------
1 | li | beijing
1 | li | shanghai
(2 rows) postgres=# INSERT INTO test (id, name, city) VALUES (2,'li','shanghai') on CONFLICT (name, city) DO UPDATE SET id = test.id + EXCLUDED.id;
INSERT 0 1
postgres=# select * from test;
id | name | city
----+------+----------
1 | li | beijing
3 | li | shanghai
(2 rows) 备注:定义 ON CONFLICT属性后,已有的用户只需更新id值(可以从上看出,只有2个约束name,city都相等时,才会更新id值,否则会增加一行)。EXCLUDED 为试图插入的值。 postgres=# create table test1(id int,name text,city text);
CREATE TABLE postgres=# ALTER TABLE test1 ADD CONSTRAINT name UNIQUE (name);
ALTER TABLE postgres=# select create_distributed_table('test1','name');
create_distributed_table
-------------------------- (1 row) postgres=# insert into test1 values (1,'li','beijing');
INSERT 0 1 postgres=# INSERT INTO test1 (id, name, city) VALUES (2,'wang','nanjing') on CONFLICT (name) DO UPDATE SET id = test1.id + EXCLUDED.id;
INSERT 0 1
postgres=# select * from test1;
id | name | city
----+------+---------
1 | li | beijing
2 | wang | nanjing
(2 rows) postgres=# INSERT INTO test1 (id, name, city) VALUES (1,'wang','nan') on CONFLICT (name) DO UPDATE SET id = test1.id + EXCLUDED.id;
INSERT 0 1
postgres=# select * from test1;
id | name | city
----+------+---------
1 | li | beijing
3 | wang | nanjing
(2 rows) 备注:可以从上看出,只要满足约束name相同,id值被更新,其他字段city若不相同则数据库中还是原来city值。

最新文章

  1. U3D 打包时找不到tag的问题
  2. spring-test测试demo
  3. cron表达式详解
  4. eclipse中的web项目路径和发布好的项目路径
  5. 快速、直接的XSS漏洞检测爬虫 – XSScrapy
  6. Linux之proc详解
  7. CSS学习------之简单图片切换
  8. 【Itext】解决Itext5大并发大数据量下输出PDF发生内存溢出outofmemery异常
  9. C#在foreach循环中修改字典等集合出错的处理
  10. 201521123085 《Java程序设计》第11周学习总结
  11. [国嵌攻略][070-095][Linux编程函数手册]
  12. revit融合
  13. java——什么是浅表副本
  14. CPDA-战略管理
  15. bzoj 2669 题解(状压dp+搜索+容斥原理)
  16. [jzoj]1729.blockenemy
  17. SQL批量更新数据
  18. DDD领域模型数据访问之对象(十一)
  19. SQLite事务 SQLite插入多条语句为什么这么慢?.net (C#)
  20. NOI.AC NOIP模拟赛 第三场 补记

热门文章

  1. SQL Server 限制IP登陆(登陆触发器运用)
  2. 你需要了解的 C++ 17 Top 19 新特性(附精彩评论)
  3. LINQ查询表达式---------where子句
  4. Resolve conflict using "MERGE_HEAD (origin/HEAD)"
  5. Standard C 语言标准函数库速查(彩色的函数列表,十分清楚)
  6. java之继承中的静态变量
  7. Ubuntu --- 安装lnmp(php7.0)
  8. EditPlus 格式化HTML JS CSS
  9. Java字符串String类操作方法详细整理
  10. 模块化 require.js 入门教学(前端必看系列)