PgSQL实现更新或插入

本文介绍了如何使用PostgreSQL的INSERT INTO...ON CONFLICT DO UPDATE语句来实现数据的更新或插入操作。此语法在9.5及以上版本中可用,要求冲突列具有唯一约束。通过这种方式,你可以避免因重复键而引发的错误,同时确保数据的正确性。
摘要由CSDN通过智能技术生成

PgSQL实现更新或插入

insert into tableA 
( C_BH, C_NAME ) values ('001','名称')

ON conflict(C_BH)
do update set
C_NAME  = '名称'

conflict里需要放唯一约束,不然会报错。
PostgreSQLconflict语法只在PostgreSQL-9.5以上才可生效,9.5以下版本直接报错

pgsql中,表格不能插入相同内容的原因可能是因为表格中存在唯一约束或主键约束。唯一约束要求表格中的某个列的值是唯一的,而主键约束要求表格中的某个列的值是唯一且非空的。当尝试插入相同内容时,pgsql会检测到违反了唯一约束或主键约束,从而导致插入失败。 要解决这个问题,你可以考虑以下几种方法: 1. 检查表格的约束:使用DESCRIBE或SHOW CREATE TABLE语句来查看表格的约束,确认是否存在唯一约束或主键约束。 2. 检查插入的数据:确保插入的数据不与表格中已有的数据重复。可以使用SELECT语句来查询表格中的数据,以确保插入的数据是唯一的。 3. 更新已有数据:如果你想插入的数据与表格中已有的数据相同,你可以考虑使用UPDATE语句来更新已有的数据,而不是插入重复的数据。 请注意,以上方法只是一些常见的解决方案,具体的解决方法可能因你的表格结构和需求而有所不同。如果问题仍然存在,请提供更多的信息,以便我能够给出更具体的建议。 #### 引用[.reference_title] - *1* *2* *3* [复杂的pgsql触发器实现数据审计:记录行变更值](https://blog.csdn.net/qq_44833403/article/details/131563079)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值