PostgreSQL数据库解决不存在就插入数据,存在就更新这个单元格的数据

文章目录

解决方法

假如列1重复,就要更新列2,则使用sql:

sql 复制代码
INSERT INTO "public".表名称 ("列1", "列2")
VALUES('列1值','新的列2值') 
ON CONFLICT ("列1")
DO UPDATE SET "列2"= '新的列2值' -- 这里把col_2这一列的数据赋值为'5555'

示例程序

对于这样的数据,以"col_1"为主键,则新插入一个数据:

sql 复制代码
INSERT INTO "public".test_table ("col_1", "col_2")
VALUES('1','5555') 

会报错重复键违反唯一约束"col_1"

情况1:当存在数据时跳过,不操作

这时候sql语句是:

sql 复制代码
INSERT INTO "public".test_table ("col_1", "col_2")
VALUES('1','5555') 
ON CONFLICT (col_1) -- 这里是写法是 ON CONFLICT (重复列名称)
DO NOTHING; -- 这里是如果出现冲突的操作,不操作就写 DO NOTHING

情况2:当存在数据时,更新这个单元格

这时的sql语句是:

sql 复制代码
INSERT INTO "public".test_table ("col_1", "col_2")
VALUES('1','5555') 
ON CONFLICT (col_1)
DO UPDATE SET "col_2"= '5555' -- 这里把col_2这一列的数据赋值为'5555'

最后的数据为:

相关推荐
夏恪4 小时前
golang如何实现滚动更新方案_golang滚动更新方案实现实战
jvm·数据库·python
2301_818008444 小时前
CSS如何让响应式图片在容器内居中_利用background-position
jvm·数据库·python
weixin_444012935 小时前
mysql如何升级版本至最新_mysql大版本平滑升级策略
jvm·数据库·python
kexnjdcncnxjs5 小时前
mysql如何优化小表的查询索引_mysql全表扫描与索引代价对比
jvm·数据库·python
一只专注api接口开发的技术猿5 小时前
京东商品实时监控选品实战:用 Open Claw API 快速搭建自动化工具
运维·数据库·自动化
万事大吉CC5 小时前
【7】Django 类视图实战指南:如何高效引用与配置
数据库·sqlite
木土雨成小小测试员5 小时前
Python测试开发之后端二完结
数据库·python·sqlite
szccyw06 小时前
如何从SQL提取年或月数据_运用YEAR与MONTH提取函数
jvm·数据库·python
重生之小比特6 小时前
【MySQL 数据库】基本查询
android·数据库·mysql
罗超驿6 小时前
4.MySQL数据表操作与CRUD详解:从建表、插入到查询的全流程
数据库·mysql