网站首页 > 技术文章 正文
在开发中我们经常会碰到这么一个场景,例如用户修改简单的个人基本信息,这个时候就需要判断用户的基本信息是否存在,如果是首次录入不存在就在表中插入一条信息,如果存在就更新表里的信息。要实现这种这种场景很简单,我们最常用的就是先查询一下用户的基本信息,执行一下select方法,如果数据存在就执行update方法,如果不存在就就执行insert 方法。这是一种解决思路。当只是很简单的条件判断时,我们也有另外一种数据库层面的解决思路就是merge into ,很多数据库都有这种语句,因为我用的oracle,这里就记录下oracle的用法,从version 9开始就支持的语法。
首先我们有一张表这里随便抽取的一张平时练习的表
这里先说下Merge into的语法,merge into中文大概意思就是合并操作
MERGE INTO table_name alias1
USING (table | view | sub_query) alias2
ON (join condition)
WHEN MATCHED THEN
UPDATE table_name SET col1 = col_val1, col2 = col2_val
WHEN NOT MATCHED THEN
INSERT (column_list) VALUES (column_values);
这个语句很好理解,操作alias1表的数据,其操作数据的来源为 alias2中数据的记录数,通过on括号中的条件进行过滤,当alias1和alias2中的数据通过on条件进行过滤后,如果存在就执行更新操作,如果不存在就执行插入操作。
现在有这么个需求:判断表中是否存在ID为7的数据,如果存在更新名字为小小明,如果不存在,插入一条小明的数据。假设场景中名字为唯一,那么我们的更新语句就可以这么写
merge into student a
using (select '7' as id from dual) s
on (a.id = s.id)
when matched then
update set a.student_name = '小明二号'
when not matched then
insert (id, student_name, fk_class) values ('7', '小明', '2')
用merge的时候大概有3个地方需要注意
1:如果using中的语句查询不出来数据,是不会执行insert方法的,因为这个语法是根据using 中的查询数据进行判断
merge into student a
using (select id from student where id = '7') s
on (a.id = s.id )
when matched then
update set a.student_name = '小明二号'
when not matched then
insert (id, student_name, fk_class) values ('7', '小明', '2')
这么写的话是不会有插入操作的,因为表中并没有id为7的数据,如果把id 改为6,因为表中有查询出的数据能成功执行update
2:语句写的时候on 中的条件记得过滤准确,不然可能会执行全表更新
merge into student a
using (select count(1)cot,id from student group by id ) s
on (a.id = s.id and cot > 0)
when matched then
update set a.student_name = '小明二号'
when not matched then
insert (id, student_name, fk_class) values ('7', '小明', '2')
这么写的话可以看出明显的错误,只要是id相等且cot大于0,那么查询出的都大于0,会执行全表更新
3:on 中的条件不能是更新操作列,不然会报错:ora-38104
merge into student a
using (select '7' as id from dual) s
on (a.id = s.id)
when matched then
update set a.id = '7'
when not matched then
insert (id, student_name, fk_class) values ('7', '小明', '2');
猜你喜欢
- 2025-07-23 欧莱雅SAP系统成功合并(欧莱雅corp部门)
- 2025-07-23 SQL 逻辑处理核心知识点全解析,从入门到精通看这篇就够了!
- 2024-10-25 Skydance宣布与派拉蒙合并 将成立价值280亿美元的“新派拉蒙”
- 2024-10-25 Oracle批量、大量Update方法总结 oracle批量更新语句
- 2024-10-25 Oracle 20c 新特性:缺省的只读 Oracle HOME 支持
- 2024-10-25 Oracle提高SQL执行效率的三种方法
- 2024-10-25 Oracle生成不重复字符串 sys_guid()
- 2024-10-25 如何通过云效Codeup完成代码合并 云效和码云
- 2024-10-25 SQL MERGE语句详解 sql的merge命令
- 2024-10-25 Oracle分区全解 oracle分区split
你 发表评论:
欢迎- 624℃几个Oracle空值处理函数 oracle处理null值的函数
- 616℃Oracle分析函数之Lag和Lead()使用
- 606℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 601℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 596℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 589℃【数据统计分析】详解Oracle分组函数之CUBE
- 577℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 565℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
-
- 国产化红利到底在哪?好多人都在瞎折腾
- Oracle 推出 Java 24,增强 AI 支持和后量子加密
- JAVA桥接模式适用场景,优缺点是什么你知道吗,这篇文章彻底讲透
- SpringBoot条件化配置(@Conditional)全面解析与实战指南
- Navicat Data Modeler使用教程十二:配置
- 软件测试|数据库的内连接,左连接,右链接分别是什么
- 每日学习“IT”是什么呢?(每日学习每日一词)
- SQLite:小众?其实它比你想象的更普及,连这个领域都有人用!
- 【推荐】一款实用且跨平台的数据库管理神器,支持Web浏览器
- Spring Batch中的JobRepository:批处理的“记忆大师”是如何工作
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端获取当前时间 (50)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (58)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)