• 技术文章 >数据库 >Oracle

    oracle中update的用法是什么

    长期闲置长期闲置2022-03-01 17:10:53原创89

    oracle中update的用法:1、用于修改表中的数据,语法为“UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值”;2、用于将两张表通过关联建立一个视图并进行更新。

    本教程操作环境:Windows10系统、Oracle 11g版、Dell G3电脑。

    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 语句用于修改表中的数据。W3school中的语法 :

    UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值。

    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).

    @H_301_73@游标法

    游标有显示游标和快速游标。

    快速游标

    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这个字段,并且是唯一索引),可以快速定位到要更新的记录上,同时可以支持复杂的查询语句。

    推荐教程:《Oracle视频教程

    以上就是oracle中update的用法是什么的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:oracle
    上一篇:oracle中substr的用法是什么 下一篇:oracle replace()函数怎么用
    PHP编程就业班

    相关文章推荐

    • oracle怎么查询归档状态• oracle怎么查询月份• oracle怎么修改注释• oracle中decode的用法是什么• oracle怎么查询不包含指定字符

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网