POSTGRESQL中ON CONFLICT的使用

在 PostgreSQL 中,ON CONFLICT 子句是用在 INSERT 语句中的一种机制,它可以帮助你处理当插入操作遇到违反唯一性约束(比如唯一索引或主键约束)时的情况。使用 ON CONFLICT 子句,你可以指定当违反唯一性约束时应该采取的操作,比如忽略这个插入,或者更新已经存在的行。

ON CONFLICT (sample_id_lims) DO UPDATE 是指当你在插入数据时,如果 sample_id_lims 字段的值导致了唯一性约束的冲突,那么不是放弃这次插入,而是更新已经存在的那一行数据。

这里有一个具体的例子:

假设你有一个名为 samples 的表,它有一个名为 sample_id_lims 的字段,该字段上有一个唯一索引。现在,你想插入一个新的样本数据,但如果 sample_id_lims 的值已经存在,你希望更新这条记录的其他字段而不是放弃插入。

sql 复制代码
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、指定唯一约束名称:

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

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

2、条件更新:

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

sql 复制代码
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 会忽略这个插入,并且不会报错。

sql 复制代码
INSERT INTO table_name (column1, column2) VALUES (value1, value2)
ON CONFLICT (column1) DO NOTHING;

4、返回插入或更新后的行:

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

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

5、使用 WHERE 子句过滤冲突的行:

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

sql 复制代码
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 子句可以帮助你以一种优雅的方式处理可能的数据插入冲突,确保数据的完整性,同时还能灵活地进行各种条件处理。

相关推荐
数据库生产实战19 小时前
Oracle 19C RAC下TRUNCATE TABLE的REUSE STORAGE选项作用和风险浅析!
数据库·oracle
小白银子20 小时前
零基础从头教学Linux(Day 60)
linux·数据库·mysql·oracle
瀚高PG实验室20 小时前
数据库安全配置指导
服务器·数据库·瀚高数据库
憋问我,我也不会20 小时前
MYSQL 命令
数据库·mysql
24K老游21 小时前
postgres15 flink cdc同步测试
数据库
无泡汽水21 小时前
MySQL入门练习50题
数据库·mysql
JIngJaneIL1 天前
助农惠农服务平台|助农服务系统|基于SprinBoot+vue的助农服务系统(源码+数据库+文档)
java·前端·数据库·vue.js·论文·毕设·助农惠农服务平台
云外天ノ☼1 天前
待办事项全栈实现:Vue3 + Node.js (Koa) + MySQL深度整合,构建生产级任务管理系统的技术实践
前端·数据库·vue.js·mysql·vue3·koa·jwt认证
小光学长1 天前
基于Vue的智慧楼宇报修平台设计与实现066z15wb(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库·vue.js
CodeBlossom1 天前
Spring Cache快速入门
java·数据库·spring