CitusDB UPSERT
2024-08-24 08:43:32
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值。
最新文章
- U3D 打包时找不到tag的问题
- spring-test测试demo
- cron表达式详解
- eclipse中的web项目路径和发布好的项目路径
- 快速、直接的XSS漏洞检测爬虫 – XSScrapy
- Linux之proc详解
- CSS学习------之简单图片切换
- 【Itext】解决Itext5大并发大数据量下输出PDF发生内存溢出outofmemery异常
- C#在foreach循环中修改字典等集合出错的处理
- 201521123085 《Java程序设计》第11周学习总结
- [国嵌攻略][070-095][Linux编程函数手册]
- revit融合
- java——什么是浅表副本
- CPDA-战略管理
- bzoj 2669 题解(状压dp+搜索+容斥原理)
- [jzoj]1729.blockenemy
- SQL批量更新数据
- DDD领域模型数据访问之对象(十一)
- SQLite事务 SQLite插入多条语句为什么这么慢?.net (C#)
- NOI.AC NOIP模拟赛 第三场 补记
热门文章
- SQL Server 限制IP登陆(登陆触发器运用)
- 你需要了解的 C++ 17 Top 19 新特性(附精彩评论)
- LINQ查询表达式---------where子句
- Resolve conflict using ";MERGE_HEAD (origin/HEAD)";
- Standard C 语言标准函数库速查(彩色的函数列表,十分清楚)
- java之继承中的静态变量
- Ubuntu --- 安装lnmp(php7.0)
- EditPlus 格式化HTML JS CSS
- Java字符串String类操作方法详细整理
- 模块化 require.js 入门教学(前端必看系列)