oracle udpate,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 on b.employee_id = e.employee_id

where e.bonus_eligible = 'N') t

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语句。

此文档整理参考的稍多,这里不再一一列出,自我学习笔记整理,无意冒犯。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值