Postgre SQL数据库实现有记录则更新无记录就新增的方法
发表于:2024-11-23 作者:千家信息网编辑
千家信息网最后更新 2024年11月23日,这篇文章主要介绍"Postgre SQL数据库实现有记录则更新无记录就新增的方法",在日常操作中,相信很多人在Postgre SQL数据库实现有记录则更新无记录就新增的方法问题上存在疑惑,小编查阅了各
千家信息网最后更新 2024年11月23日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安全错误
数据库的锁怎样保障安全
如何安全的在数据库中保存密码
网络安全管理师课程
徐州加工软件开发注意事项
汕头市网络安全技术培训课程
宁波教育软件开发
网络安全周落实计划
原神云服务器爆满
数据库tns连接超时
服务器的维护和安全
网络安全大赛中职组
微软的软件开发特点
江苏企业软件开发费用
基础软件开发测试
五邑大学网络安全
网络安全需注意
navcat导出数据库
租用服务器日志管理
如何动态查看服务器日志
荔湾网络安全运维联系方式
电脑总是显示正在连接服务器
网络技术计算机三级视频
腾讯云轻量服务器很卡
互联网科技扁平插画
女孩适合学网络安全
网络安全应用技术专业单招分数线
python完美数据库
软件开发结业论文
无线网络技术规范
网络安全数据安全的重要意义
手游软件开发工程师