首頁  >  文章  >  資料庫  >  oracle中update的用法是什麼

oracle中update的用法是什麼

WBOY
WBOY原創
2022-03-01 17:10:5329965瀏覽

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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn