- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章PostgreSQL的upsert实例操作(insert on conflict do)由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
建表语句:
1
2
3
4
5
6
7
8
9
10
11
12
|
DROP
TABLE
IF EXISTS
"goods"
;
CREATE
TABLE
"goods"
(
"store_cd"
int4
NOT
NULL
,
"good_cd"
varchar
(50)
COLLATE
"pg_catalog"
.
"default"
NOT
NULL
,
"name"
varchar
(255)
COLLATE
"pg_catalog"
.
"default"
);
INSERT
INTO
"goods"
VALUES
(101,
'1'
,
'张三'
);
INSERT
INTO
"goods"
VALUES
(102,
'2'
,
'李四'
);
INSERT
INTO
"goods"
VALUES
(103,
'3'
,
'王五'
);
ALTER
TABLE
"goods"
ADD
CONSTRAINT
"pr_cd_key"
PRIMARY
KEY
(
"store_cd"
,
"good_cd"
);
|
表数据:
数据存在则更新数据,不存在则插入数据 。
1
2
3
4
5
6
7
|
INSERT
INTO
GOODS
VALUES
( 104,
'4'
,
'赵六'
)
ON
CONFLICT
ON
CONSTRAINT
pr_key_cd DO
UPDATE
SET
NAME
=
'更新'
WHERE
GOODS.STORE_CD =
'104'
AND
GOODS.GOOD_CD =
'4'
|
pr_key_cd为必须为唯一主键,也可以用下面写法(注意:必须保证筛选出数据唯一) 。
1
2
3
4
5
6
7
|
INSERT
INTO
GOODS
VALUES
( 104,
'4'
,
'赵六'
)
ON
CONFLICT ( STORE_CD, GOOD_CD ) DO
UPDATE
SET
NAME
=
'更新'
WHERE
GOODS.STORE_CD =
'104'
AND
GOODS.GOOD_CD =
'4'
|
上面的两种的写法,是先执行insert如果主键冲突则执行update,没有冲突就执行insert了。要是想先执行update语句呢?
update更新失败执行insert,更新成功则执行update.
1
2
3
|
WITH
TABLE1
AS
(
UPDATE
GOODS
SET
NAME
=
'更新'
WHERE
STORE_CD =
'104'
AND
GOOD_CD =
'4'
RETURNING * )
INSERT
INTO
GOODS
SELECT
104,
'4'
,
'赵六'
WHERE
NOT
EXISTS (
SELECT
1
FROM
TABLE1
WHERE
STORE_CD =
'104'
AND
GOOD_CD =
'4'
)
|
补充:Postgresql插入或更新操作upsert 。
幂等性的一个要求是多次操作的结果一致。对于update操作,多次直接的结果都是最后update的值,是满足需求的。但对于insert,如果已经插入,第二次会报错,duplicate error, 主键重复或者unique key duplicate。所以需要做一下处理.
最简单的就是,try-catch,当报错的时候,调用update去更新,或者策略更简单点,直接返回就行,不需要更新,以第一条为准.
PostgreSQL从9.5之后就提供了原子的upsert语法: 不存在则插入,发生冲突可以update.
Inert语法 。
官方文档: https://www.postgresql.org/docs/devel/sql-insert.html 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
[
WITH
[ RECURSIVE ] with_query [, ...] ]
INSERT
INTO
table_name [
AS
alias ] [ ( column_name [, ...] ) ]
[ OVERRIDING { SYSTEM |
USER
} VALUE ]
{
DEFAULT
VALUES
|
VALUES
( { expression |
DEFAULT
} [, ...] ) [, ...] | query }
[
ON
CONFLICT [ conflict_target ] conflict_action ]
[ RETURNING * | output_expression [ [
AS
] output_name ] [, ...] ]
where
conflict_target can be one
of
:
( { index_column_name | ( index_expression ) } [
COLLATE
collation ] [ opclass ] [, ...] ) [
WHERE
index_predicate ]
ON
CONSTRAINT
constraint_name
and
conflict_action
is
one
of
:
DO NOTHING
DO
UPDATE
SET
{ column_name = { expression |
DEFAULT
} |
( column_name [, ...] ) = [ ROW ] ( { expression |
DEFAULT
} [, ...] ) |
( column_name [, ...] ) = ( sub-
SELECT
)
} [, ...]
[
WHERE
condition ]
|
index_column_name 。
The name of a table_name column. Used to infer arbiter indexes. Follows CREATE INDEX format. SELECT privilege on index_column_name is required. 。
index_expression 。
Similar to index_column_name, but used to infer expressions on table_name columns appearing within index definitions (not simple columns). Follows CREATE INDEX format. SELECT privilege on any column appearing within index_expression is required. 。
使用示例 。
创建表 。
1
2
3
4
5
|
CREATE
TABLE
"test"
.
"upsert_test"
(
"id"
int4
NOT
NULL
,
"name"
varchar
(255)
COLLATE
"pg_catalog"
.
"default"
)
;
|
当主键id冲突时,更新其他字段 。
1
2
3
4
|
INSERT
INTO
test.upsert_test(id,
"name"
)
VALUES
(1,
'm'
),(2,
'n'
),(4,
'c'
)
ON
conflict(id) DO
UPDATE
SET
"name"
= excluded.
name
;
|
did 冲突的主键 。
EXCLUDED 代指要插入的记录 。
当主键或者unique key发生冲突时,什么都不做 。
1
2
3
|
INSERT
INTO
test.upsert_test(id,
"name"
)
VALUES
(1,
'm'
),(2,
'n'
),(4,
'c'
)
ON
conflict(id) DO NOTHING;
|
以上为个人经验,希望能给大家一个参考,也希望大家多多支持我。如有错误或未考虑完全的地方,望不吝赐教.
原文链接:https://yunan.blog.csdn.net/article/details/100897511 。
最后此篇关于PostgreSQL的upsert实例操作(insert on conflict do)的文章就讲到这里了,如果你想了解更多关于PostgreSQL的upsert实例操作(insert on conflict do)的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
Postgres 10 和 11 的插入规范说: ON CONFLICT [ conflict_target ] conflict_action 我有一张 table : create table c
我的理解是conflict serializable 隐含serializable。我不确定这如何让他们与众不同。可序列化是否意味着冲突可序列化? 最佳答案 冲突可序列化是可序列化的一个子集,因此仅仅
在数据库理论中,“冲突可序列化”和“冲突等价”有什么区别? 我的教科书有一节是关于冲突可序列化的,但掩盖了冲突等价性。这些可能都是我熟悉的概念,但我不熟悉术语,所以我正在寻找解释。 最佳答案 DBMS
我有一个项目一直在 Xcode 4.4.1 中进行,我想回到以前的分支。(注意分支并不复杂,而是代表线性发展) 当我选择上一个分支时有一个警告 UserInterfaceState.xcusersta
我得到了一个 environment.ubuntu.yml文件,以便能够创建 conda 环境。但是,运行 conda create env --file environment.ubuntu.yml
我浏览了互联网,找不到我的问题的清晰简洁的答案。我想知道如果我将相同强度的信号驱动到同一根电线上会发生什么,其中一个是逻辑 1,另一个是逻辑 0?如果我想要一个“获胜”的信号,因为没有更好的词,我该怎
我在2个网站上有2个不同的图片: http://www.siteA.com/avatar.png http://www.siteB.com/avatar.png 如果我创建具有2个起源的Amazon
我正在 Labview 中开发一个数据采集程序,该程序使用多个转换阶段、相机、高速数字化仪和其他仪器。我正在一台计算机上开发该应用程序,并将其部署到另一台计算机上。开发计算机有labview 2013
能否请您帮助我理解为什么乐观并发更新会有这样的结果。 比如说,我有以下文件: { "phrase": "some phrase", "id": "5d1341797e2ed599", "_
我想安装这两个包: “anahkiasen/前任”:“开发大师” "vespakoen/menu": "dev-master" 但是 composer 说它们每个都依赖于这个包的不同版本: "anah
我在运行 powershell 时遇到以下错误 $thumbprint=$(az webapp config ssl upload --certificate-file $Path --certifi
我不太确定这是否是我使用的 SQLite 版本的问题。但实际上我并没有直接使用 native SQLite (dll),我使用的是 System.Data.SQLite 版本 1.0.108.0 看起
我有一个具有 iBeacon 服务和标准 BLE 服务的芯片。 我想使用 iBeacon 服务在进入 BLE 信号范围时触发我正在开发的应用。 激活后,我希望应用程序使用 CoreBluetooth
建表语句: ? 1
我使用此链接中的示例创建了测试 Telegram 机器人控制台应用程序 https://github.com/TelegramBots/Telegram.Bot.Examples 这是我的主要 pub
我有这个 hpp 文件: struct rte_spinlock_t; class A { public: void init(); private:
我已经从 GitHub 中提取了文件。现在我需要创建一个合并冲突。 如何在 GitHub 上故意创建合并冲突? 最佳答案 在两个分支中编辑同一行,并尝试合并 Merge conflicts in gi
我是这个 repo 的管理员。在这个 PR 中,我删除了多个文件并将这些更改从本地合并到源/开发。将 origin/develop 合并到 origin/master 时,我遇到了我删除的四个文件之一
我使用 Azure 表存储从 MVC 应用程序记录访问者信息,但有时会引发以下异常: [WebException: The remote server returned an error: (409)
我有一张 table : create table c ( e text not null, m text not null, p numeric not null,
我是一名优秀的程序员,十分优秀!