登录  /  注册
首页 > 数据库 > Oracle > 正文

oracle中update的用法是什么

WBOY
发布: 2022-03-01 17:10:53
原创
29771人浏览过
oracle中update的用法:1、用于修改表中的数据,语法为“update 表名称 set 列名称 = 新值 where 列名称 = 某值”;2、用于将两张表通过关联建立一个视图并进行更新。

oracle中update的用法是什么

本教程操作环境: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中文网其它相关文章!

智能AI问答
PHP中文网智能助手能迅速回答你的编程问题,提供实时的代码和解决方案,帮助你解决各种难题。不仅如此,它还能提供编程资源和学习指导,帮助你快速提升编程技能。无论你是初学者还是专业人士,AI智能助手都能成为你的可靠助手,助力你在编程领域取得更大的成就。
相关标签:
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
关于CSS思维导图的课件在哪? 课件
凡人来自于2024-04-16 10:10:18
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2024 //m.sbmmt.com/ All Rights Reserved | php.cn | 湘ICP备2023035733号