Oracle中如何使用update语句
导读:这篇文章给大家介绍了“Oracle中如何使用update语句”的相关知识,讲解详细,步骤过程清晰,对大家进一步学习和理解“Oracle中如何使用update语句”有一定的帮助,希望大家阅读完这篇文章能有所收获。下面就请大家跟着小编的思路一起...
这篇文章给大家介绍了“Oracle中如何使用update语句”的相关知识,讲解详细,步骤过程清晰,对大家进一步学习和理解“Oracle中如何使用update语句”有一定的帮助,希望大家阅读完这篇文章能有所收获。下面就请大家跟着小编的思路一起来学习一下吧。
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中如何使用update语句”的介绍了,感谢各位的阅读,希望文本对大家有所帮助。如果想要了解更多知识,欢迎关注网络,小编每天都会为大家更新不同的知识。
声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!
若转载请注明出处: Oracle中如何使用update语句
本文地址: https://pptw.com/jishu/651437.html