Oracle执行Update语句的几种方式
Oracle没有update from语法,可以通过四种写法实现同样的功能:
一、标准update语法(常用、速度可能最慢)
当更新的表示单个或者被更新的字段不需要关联表带过来,此法是最好的选择。
update a set a.c2= (select b.c2from b where a.c1=b.c1) where exists (select 1 from b where a.c1=b.c1)
二、内联视图更新(关联主键字段,速度较快)
inline view更新法就是更新一个临时建立的视图。
方案:更新一个临时建立的视图。要求B表的主键字段必须在where条件中,并且是以=号来关联被更新表。
update (select a.c2 as ac2,b.c2 as bc2 from a, b where a.c1=b.c1 and a.c3='2011') as M set ac2=bc2
三、merge更新法 (关联字段非主键时,速度较快)
merge是oracle特有的语句,语法如下:
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);
原理分析:在alias2中Select出来的数据,每一条都跟alias1进行 ON (join condition)的比较,如果匹配,就对alias1表进行更新的操作(Update),如果不匹配,就对alias1表进行插入操作(Insert)。
执行merge不会返回影响的行数,最多只能两个表关联。
merge into a using b on (a.c1=b.c1 and a.c3='2011') when matched then update a.c2=b.c2
四、快速游标更新法(复杂逻辑时,效率很高)
语法:
begin for cr in (查询语句) loop --循环 update table_name set ... --更新语句(根据查询出来的结果集合) end loop; --结束循环 end;
begin for cur in (select a.rowid ,b.c2 from a, b where a.c1=b.c1 and a.c3='2011' ) loop UPDATE a set c2=cur.c2 where rowid=cur.rowid; end loop; end;
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
oracle ORA-00988 missing or invalid password 错误
在设置数据库实例的密码时,注意不要以数字开头,否则您将会遇到 ORA-00988 missing or invalid password (口令缺失或无效) 错误2015-01-01Oracle数据的插入insert、更新update、删除delete、truncate举例详解
SQL语法是所有操作的基础,包括创建、查询、更新和删除数据,下面这篇文章主要给大家介绍了关于Oracle数据的插入insert、更新update、删除delete、truncate的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下2024-07-07Windows server 2019安装Oracle 19c的图文教程
Oracle是是一款高效、可靠、吞吐量高的数据库,本文主要介绍了Windows server 2019安装Oracle 19c的图文教程,具有一定的参考价值,感兴趣的可以了解一下2024-04-04
最新评论