Oracle 使用MERGE INTO 語句更新數據


轉http://www.cnblogs.com/jiangguang/archive/2012/12/24/2830581.html

/*Merge into 詳細介紹
MERGE語句是Oracle9i新增的語法,用來合並UPDATE和INSERT語句。
通過MERGE語句,根據一張表或子查詢的連接條件對另外一張表進行查詢,
連接條件匹配上的進行UPDATE,無法匹配的執行INSERT。
這個語法僅需要一次全表掃描就完成了全部工作,執行效率要高於INSERT+UPDATE。
*/
/*語法:
MERGE [INTO [schema .] table [t_alias]
USING [schema .] { table | view | subquery } [t_alias]
ON ( condition )
WHEN MATCHED THEN merge_update_clause
WHEN NOT MATCHED THEN merge_insert_clause;
*/

 

merge into users

using doctor

on (users.user_id = doctor.doctorid)

when matched then

  update set users.user_name = doctor.doctorname      --update 和 insert 語句均可以簡寫,省略 表名等

when not matched then

  insert

  values

    (doctor.doctorid,

     doctor.doctorid,

     '8736F1C243E3B14941A59FF736E1B5A8',

     doctor.doctorname,

     sysdate,

     'T',

     ' ',

     doctor.deptid,

     'b319dac7-2c5c-496a-bc36-7f3e1cc066b8');

 

 

限定條件位置:

merge into MDC_DiabetesRecord  a
using EHR_HealthRecord b
on (a.empiid = b.empiid  and  a.phrid='3301850040200000' ) --限制條件 a.phrid='3301850040200000'  可以 置於 condition 處
when matched then
  update set a.status = '9' ;  
 
   merge into MDC_DiabetesRecord  a
using EHR_HealthRecord b
on (a.empiid = b.empiid  )
when matched then
  update set a.status = '9'  where  a.phrid='3301850040200000'  ;  --可以 置於 update 處

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM