oracleudpate,Oracle四种update⽅法总结
Oracle 四种update⽅法总结
Oracle除了提供标准的update语句之外还提供了其他的⼀些数据更新⽅式以应对不同的应⽤场景:
—–[oracle的update原理]
update_statement ::=
UPDATE {table_reference | [THE] (subquery1)} [alias]
SET {
column_name = {sql_expression | (subquery2)}
| (column_name [,column_name]...) = (subquery3)}
[,{column_name = {sql_expression | (subquery2)}
| (column_name [,column_name]...) = (subquery3)
}]...
[WHERE {search_condition | CURRENT_OF cursor_name}] [returning_clause]
标准Update
update join view
merge into
游标法
标准update
Update 语句⽤于修改表中的数据。W3school中的语法 :
UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值。 —— [ w3school]
update join view
update join view 就是⾸先将两张表通过关联建⽴⼀个视图然后将对视图进⾏更新,进⽽达到更新源表⽬的 :
update (select bonus
from employee_bonus b
inner join employees e ployee_id = e.employee_id
where e.bonus_eligible = 'N') tupdate语法大全
set t.bonus = 0
就像上⾯原理⾥⾯讲的⼀样,括号⾥⾯的是⼀个视图,set中是需要更新的字段,这个⽅法直接且⾼效,但是限制⽐较死,其中的employees 表的主键必须出现在where条件中,否则会报错,ORA-01779:⽆法修改与⾮键值保存表对应的列。
merge into
merge into是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)的⽐较,如果匹配,就进⾏更新的操作(Update),如果不匹配,就进⾏插⼊操作(Insert).
merge into 描述:
The optimizer can choose a sort merge join over a hash join for joining large amounts of data if any of the following conditions are true:
The join condition between two tables is not an equi-join.
Because of sorts already required by other operations,the optimizer finds it is cheaper to use a sort
merge than a hash join
⽤merge的话是必须进⾏排序的,就是说它会读取两个表的数据然后按照⼀定顺序进⾏merge~这个是有开销的。执⾏merge不会返回影响的⾏数。Merge语句的写法⽐较繁琐,并且最多只能两个表关联,复杂的语句⽤merge更新法将⼒不从⼼且效率差。
游标法
游标有显⽰游标和快速游标。
快速游标
begin
for cur in (table|subquery) loop
update_statement
end loop;
end;
显⽰游标
SET SERVEROUTPUT ON
DECLARE
CURSOR emp_cursor IS
SELECT empno,ename FROM emp;
BEGIN
FOR Emp_record IN emp_cursor LOOP
update_statement;
END LOOP;
END;
使⽤游标好处很多,for循环给我们提供了更新批量数据的⽅法,再加上oracle的rowid物理字段(oracle
默认给每个表都有rowid这个字段,并且是唯⼀索引),可以快速定位到要更新的记录上,同时可以⽀持复杂的查询语句。
更新⽅法:
场景
标准update语法
单表更新或较简单的语句采⽤使⽤此⽅案更优。
update join view
两表关联且被更新表通过关联表主键关联的,采⽤此⽅案更优。
merge into
两表关联且被更新表不是通过关联表主键关联的,采⽤此⽅案更优。
游标
多表关联且逻辑复杂的,采⽤此⽅案更优
通常对于两张表之间的更新, 数据更新的速度为 Update join view , merge into,游标,标准Update语句。此⽂档整理参考的稍多,这⾥不再⼀⼀列出,⾃我学习笔记整理,⽆意冒犯。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论