Postgre SQL数据库实现有记录则更新无记录就新增的方法
发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,这篇文章主要介绍"Postgre SQL数据库实现有记录则更新无记录就新增的方法",在日常操作中,相信很多人在Postgre SQL数据库实现有记录则更新无记录就新增的方法问题上存在疑惑,小编查阅了各
千家信息网最后更新 2025年11月07日Postgre SQL数据库实现有记录则更新无记录就新增的方法
这篇文章主要介绍"Postgre SQL数据库实现有记录则更新无记录就新增的方法",在日常操作中,相信很多人在Postgre SQL数据库实现有记录则更新无记录就新增的方法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"Postgre SQL数据库实现有记录则更新无记录就新增的方法"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
在PostgreSQL中使用on conflict关键字,可以很方便地实现有则更新无则新增的功能:
创建一张测试表,id为自增主键,cust_id为用户id,name为用户名称:
create table test_cust (id serial primary key, cust_id int, name varchar(20));
为字段cust_id创建唯一约束:
create unique index idx_tb_cust_id_unq on test_cust( cust_id);
向表中新增三条记录:
insert into test_cust ( cust_id,name) values (1, 'a'); insert into test_cust ( cust_id,name) values (2, 'b'); insert into test_cust ( cust_id,name) values (3, 'c'); select * from test_cust;
再次向表中增加cust_id为3的记录时,由于cust_id有唯一约束,新增记录会报错:
insert into test_cust ( cust_id,name) values (3, 'b');
使用on conflict语句实现更新cust_id为3的记录,将该用户的name修改为e:
insert into test_cust ( cust_id,name) values (3, 'e') on conflict(cust_id) do update set name='e'; select * from test_table;
如果有记录的时候不做任何操作,没有记录则新增,可以这样来实现:
insert into test_cust ( cust_id,name) values (3, 'e') on conflict(cust_id) do nothing;
需要注意的是:conflict(cust_id) 中的字段cust_id必须创建有唯一约束。
到此,关于"Postgre SQL数据库实现有记录则更新无记录就新增的方法"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!
更新
方法
数据
数据库
学习
用户
字段
更多
帮助
实用
接下来
关键
关键字
再次
功能
名称
文章
时候
理论
知识
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络技术ui设计
上半年5G网络技术ppt
网络安全与防范班会
网络安全 誓词
江苏电脑软件开发服务费
日语专业学软件开发
我的世界游戏服务器哪个好玩
金蝶kis云数据库
数据库技术的前沿动态
盛世芳华服务器繁忙如何处理
服务器安全组有什么作用
盐城众安源网络技术有限公司
拒不履行网络安全保护义务案
网络安全培训学习现状
如何开始软件开发计划
服务器多大内存
深圳第三方软件开发怎么样
网络安全物理传输
在网上学习网络技术的网站
南京电大试卷网络技术
linux启动服务器命令
服务器windows10旗舰版
url 服务器地址
网络安全坐标图片
)数据库技术国三
镇江软件开发怎么样
宏碁笔记本怎么进网络安全模式
准备上市的网络安全公司
幼儿园网络安全突发事件信息
深信服网络安全培训