Postgre SQL数据库实现有记录则更新无记录就新增的方法
发表于:2025-01-20 作者:千家信息网编辑
千家信息网最后更新 2025年01月20日,这篇文章主要介绍"Postgre SQL数据库实现有记录则更新无记录就新增的方法",在日常操作中,相信很多人在Postgre SQL数据库实现有记录则更新无记录就新增的方法问题上存在疑惑,小编查阅了各
千家信息网最后更新 2025年01月20日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安全错误
数据库的锁怎样保障安全
十堰软件开发团队
网络安全法几个原则几个主张
软件开发项目组是什么样的
arcgis怎么查看数据库
面向对象方法把软件开发
如何在网页上登陆服务器邮箱
租服务器 便宜
软件开发企业工时统计表
数据库应用英文简称
大学生网络安全ppt素材
全球军事火力数据库
阳江专业软件开发代理价格
数据库怎样计算功能点
查看服务器安全日志
数据库信息量达到两亿
芜湖市网络安全宣传
河南紫荆网络安全科技园
抗ddos攻击服务器
大旗网软件开发工程师
省联社网络安全建议
隐藏服务器真实ip地址
投资网络安全生态链
大学网络安全教育开头
大兴区管理软件开发质量保障
自动化测试数据库数据检查
怎么创建学生选课系统数据库
安庆市网络安全与执法
larval 数据库配置
何积丰院士讲网络安全问题
电大网络安全技术考核册