PostgreSQL中ON CONFLICT的使用及一些扩展用法

 更新时间:2024年06月04日 09:33:45   作者:围城客  
Postgres ON CONFLICT是PostgreSQL数据库中的一个功能,用于处理插入或更新数据时的冲突情况,下面这篇文章主要给大家介绍了关于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 的值已经存在,你希望更新这条记录的其他字段而不是放弃插入。

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

on conflict 用法真的很方便,不存在就插入,存在可以更新 可以do nothing,就是用起来要注意几点

  • 字段必须完全同名。试了半天不行,改了同名就行。
  • 拿不到原表的内容。退而求其次用原表做一个内连接就行,取原值然后想怎么玩都行。下面这个例子就是取原值并加上新统计值更新回原表。
  • 建临时表可以加入很多自己需要的内容,操作空间更大
  • excluded代表新选择出来的内容。
	insert into plate_no_info  
	select plate_no,total_orders ,first_parking_time,last_parking_time
	from (
	select t1.plate_no,(plate_no_info.total_orders + cnt ) as total_orders,plate_no_info.first_parking_time,t1.last_parking_time
	from (
	select plate_no,count(id) cnt,min(parking_time) first_parking_time,max(parking_time) last_parking_time
	from order_list 
	WHERE created_at > CURRENT_DATE - 1
	and plate_no ~'^[\u2e80-\ua4cf]|[\uf900-\ufaff]|[\ufe30-\ufe4f]'
	GROUP BY plate_no
	) t1,
	plate_no_info
	WHERE 1=1
	AND t1.plate_no = plate_no_info.plate_no
	)
	as t_temp
	on conflict(plate_no) 
-- 	do NOTHING
	do update 
	set 
	total_orders = excluded.total_orders,
	first_parking_time = excluded.first_parking_time,
	last_parking_time = excluded.last_parking_time;

总结

到此这篇关于PostgreSQL中ON CONFLICT的使用及一些扩展用法的文章就介绍到这了,更多相关PGSQL中ON CONFLICT使用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • PostgreSQL中json数据类型详解

    PostgreSQL中json数据类型详解

    json数据也可以被存储为text,但是 与text数据类型相比,JSON 数据类型的优势在于能强制要求每个被存储的值符合 JSON 规则,这篇文章主要介绍了PostgreSQL中json数据类型,需要的朋友可以参考下
    2023-04-04
  • postgresql SQL语句变量的使用说明

    postgresql SQL语句变量的使用说明

    这篇文章主要介绍了postgresql SQL语句变量的使用说明,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • PostgreSQL截取字符串到指定字符位置详细示例

    PostgreSQL截取字符串到指定字符位置详细示例

    这篇文章主要给大家介绍了关于PostgreSQL截取字符串到指定字符位置的相关资料,PostgreSQL数据库拼接字符串函数是一种非常重要的函数,使用它可以方便地将不同的字符串进行拼接操作,从而得到我们需要的结果,需要的朋友可以参考下
    2023-07-07
  • Docker环境实现PostgreSQL自动备份的流程步骤

    Docker环境实现PostgreSQL自动备份的流程步骤

    本文详细介绍了如何在Ubuntu系统中安装Docker,然后在Docker容器内安装和配置PostgreSQL数据库,接着,重点讲解了如何在PostgreSQL中安装和配置pg_rman工具,用于数据库的备份和恢复操作,文章还涵盖了创建定时备份任务以及删除备份的步骤,需要的朋友可以参考下
    2024-11-11
  • Postgresql设置远程访问的方法(需要设置防火墙或者关闭防火墙)

    Postgresql设置远程访问的方法(需要设置防火墙或者关闭防火墙)

    这篇文章主要介绍了Postgresql设置远程访问的方法(需要设置防火墙或者关闭防火墙),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-03-03
  • postgresql数据库 timescaledb 时序库 把大数据量表转换为超表的问题

    postgresql数据库 timescaledb 时序库 把大数据量表转换为超表的问题

    这篇文章主要介绍了postgresql数据库 timescaledb 时序库 把大数据量表转换为超表,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-02-02
  • PostgreSQL表膨胀监控案例(精确计算)

    PostgreSQL表膨胀监控案例(精确计算)

    这篇文章主要介绍了PostgreSQL表膨胀监控案例(精确计算),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • 如何修改Postgresql默认账号postgres的密码

    如何修改Postgresql默认账号postgres的密码

    PostgreSQL数据库创建一个postgres用户作为数据库的管理员,密码随机,所以需要修改密码,这篇文章主要给大家介绍了关于如何修改Postgresql默认账号postgres的密码,需要的朋友可以参考下
    2023-10-10
  • PostgreSQL 中 VACUUM 操作的锁机制详细对比解析

    PostgreSQL 中 VACUUM 操作的锁机制详细对比解析

    PostgreSQL 提供了三种主要的 VACUUM 操作:AutoVACUUM、VACUUM 和 VACUUM FULL,它们在锁机制上有显著差异,下面给大家分享PostgreSQL 中 VACUUM 操作的锁机制详细对比解析,感兴趣的朋友一起看看吧
    2025-05-05
  • postgresql 补齐空值、自定义查询字段并赋值操作

    postgresql 补齐空值、自定义查询字段并赋值操作

    这篇文章主要介绍了postgresql 补齐空值、自定义查询字段并赋值操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01

最新评论