POSTGRESQL中ON CONFLICT的使用

news/2024/7/9 20:41:34 标签: postgresql, 数据库

        在 PostgreSQL 中,ON CONFLICT 子句是用在 INSERT 语句中的一种机制,它可以帮助你处理当插入操作遇到违反唯一性约束(比如唯一索引或主键约束)时的情况。使用 ON CONFLICT 子句,你可以指定当违反唯一性约束时应该采取的操作,比如忽略这个插入,或者更新已经存在的行。
        ON CONFLICT (sample_id_lims) DO UPDATE 是指当你在插入数据时,如果 sample_id_lims 字段的值导致了唯一性约束的冲突,那么不是放弃这次插入,而是更新已经存在的那一行数据。
这里有一个具体的例子:
假设你有一个名为 samples 的表,它有一个名为 sample_id_lims 的字段,该字段上有一个唯一索引。现在,你想插入一个新的样本数据,但如果 sample_id_lims 的值已经存在,你希望更新这条记录的其他字段而不是放弃插入。

INSERT INTO samples (sample_id_lims, data_field1, data_field2)
VALUES ('123', 'New Data 1', 'New Data 2')
ON CONFLICT (sample_id_lims) DO UPDATE
SET data_field1 = EXCLUDED.data_field1,
    data_field2 = EXCLUDED.data_field2;

        在这个例子中,如果 sample_id_lims 为 '123' 的记录已经存在,那么 ON CONFLICT 子句会触发,并执行 DO UPDATE 操作。SET 子句用于更新冲突行的 data_field1 和 data_field2 字段。关键字 EXCLUDED 用来引用那些原本尝试插入但发生冲突的值。
通过使用 ON CONFLICT 子句,你可以确保表中的数据保持唯一性,同时仍然可以通过更新操作来应对重复的插入尝试。

ON CONFLICT 子句在 PostgreSQL 中的使用不仅限于简单的 UPDATE 操作。这里有一些扩展用法:

1、指定唯一约束名称:
如果表中有多个唯一约束,你可以通过唯一约束的名称指定应对哪个约束的冲突。
 

INSERT INTO table_name (column1, column2) VALUES (value1, value2)
ON CONFLICT ON CONSTRAINT constraint_name
DO NOTHING; -- 或者 DO UPDATE ...

2、条件更新:
在执行 UPDATE 操作时,可以加入 WHERE 子句来设置条件,仅在满足某些条件时才更新。

INSERT INTO table_name (column1, column2) VALUES (value1, value2)
ON CONFLICT (column1) DO UPDATE
SET column2 = EXCLUDED.column2
WHERE table_name.column3 > 10;


3、使用 DO NOTHING:
如果你不想在发生冲突时执行任何操作,可以使用 DO NOTHING。这样,如果插入的数据违反了唯一性约束,PostgreSQL 会忽略这个插入,并且不会报错。

INSERT INTO table_name (column1, column2) VALUES (value1, value2)
ON CONFLICT (column1) DO NOTHING;

4、返回插入或更新后的行:
通过 RETURNING 子句,你可以在 INSERT 操作完成后返回插入或更新的行的信息。

INSERT INTO table_name (column1, column2) VALUES (value1, value2)
ON CONFLICT (column1) DO UPDATE
SET column2 = EXCLUDED.column2
RETURNING *;


5、使用 WHERE 子句过滤冲突的行:
你可以在 ON CONFLICT 子句中使用 WHERE 来过滤哪些冲突行应该被更新。

INSERT INTO table_name (column1, column2, status) VALUES (value1, value2, 'pending')
ON CONFLICT (column1) WHERE (table_name.status = 'active') DO UPDATE
SET column2 = EXCLUDED.column2;

上面的例子中,只有当冲突行的 status 字段为 'active' 时,才会执行 UPDATE 操作。
使用 ON CONFLICT 子句可以帮助你以一种优雅的方式处理可能的数据插入冲突,确保数据的完整性,同时还能灵活地进行各种条件处理。
 


http://www.niftyadmin.cn/n/5316823.html

相关文章

IPC之十六:D-Bus的标准接口、自省机制和服务接口的具体实现方法

D-Bus的规范中提供了一系列的标准接口,绝大多数有D-Bus接口的系统调用都会实现这些标准接口,这些标准接口中包括D-Bus的自省(Introspection)机制,自省机制可以让我们通过一个标准接口了解一个D-Bus服务的各种方法的调用方法,本文将…

JSP使用websocket

jsp增加websocket $(function(){registerWebsocket(); });var ws; function registerWebsocket() {// 注册路径 加上自己的用户名ws new WebSocket("ws://127.0.0.1:8081/client/notify/test")//连接成功建立的回调方法ws.onopen function () {ws.send("客户…

DevEco Studio for Mac:zsh: command not found: ohpm

一、检查是否配置有ohpm环境 1、新打开一个终端输入export,查看是否有 ohpm路径: 二、如果没有找到ohpm路径,开始配置环境 。 1、查找本机ohpm路径,并记录ohpm解释器的路径: 2、打开终端工具,执行命令 ech…

Lombok @Data使用的坑

前言 ​ 在开发过程中,Lombok为我们提供了非常便捷的开发。使用注解,就能帮助我们生成get set 方法,使代码看起来更加优雅。但是Data注解在有些情况下会有坑, 使用过程中慎用。 坑在什么地方 Data public class Person1 {private String i…

2024年网络工程师10大必备软件,最新安装包分享

功夫再高,也怕菜刀。作为网络工程师,我们手中的菜刀是什么? 以下10大网工必备软件都已整理好安装包,需要的朋友可以在文末获取。 1、Cisco Packet Tracer(思科模拟器) Cisco Packet Tracer 是由Cisco公司发…

第七讲_css浮动

css浮动 1. 设置浮动2. 浮动的特点3. 浮动的影响4. 解决浮动的影响4.1 解决父元素高度塌陷的问题4.2 解决对兄弟元素影响问题 1. 设置浮动 浮动是通过float属性设置,float取值范围: none:不浮动,默认值。left:向左浮…

leetcode-2645 构造有效字符串的最小插入数

题目链接 2645. 构造有效字符串的最少插入数 - 力扣(LeetCode) 解题思路 动态规划 1、定义状态d[i]为将前i个字符(为了方便编码,下标从1开始)拼凑成若干个abc所需要的最小插入数。那么初始状态d[0]0,最终…

【WinForms 窗体】常见的“陷阱”

当涉及到 WinForms 窗体编程时,我们可能会遇到一些常见的问题。在本篇博客中,我将为你提供一些常见问题的解决方案。 跨线程访问控件 在 WinForms 中,当在非UI线程上执行操作并尝试访问 UI 控件时,会引发跨线程访问异常。为了解决…