1. <var id="fe6gj"></var>

    <rp id="fe6gj"><nav id="fe6gj"></nav></rp>

    <noframes id="fe6gj"><cite id="fe6gj"></cite>

    <ins id="fe6gj"><button id="fe6gj"><p id="fe6gj"></p></button></ins>
    1. <tt id="fe6gj"><i id="fe6gj"><sub id="fe6gj"></sub></i></tt>
        始創于2000年 股票代碼:831685
        咨詢熱線:0371-60135900 注冊有禮 登錄
        • 掛牌上市企業
        • 60秒人工響應
        • 99.99%連通率
        • 7*24h人工
        • 故障100倍補償
        您的位置: 網站首頁 > 幫助中心>文章內容

        Oracle中MERGE INTO的用法

        發布時間:  2012/8/30 16:45:57

        自從版本9i之后,對于“有則更新,無則插入”有了一個新的用法,不需要再執行2次SQL了。


        merge 命令可以用來用一個表中的數據來修改或者插入到另一個表。插入或者修改的操作取決于on子句的條件。MERGE INTO本來應該是用來合并表的,不過因為其特性,根據用途不同可以用在以下場合:
        -
         

        關鍵字、參數

        into 子句
        在into子句中指定所要修改或者插入數據的目標表

        using 子句
        在using子句中指定用來修改或者插入的數據源。數據源可以是表、視圖或者一個子查詢語句。

        on 子句
        在on子句中指定執行插入或者修改的滿足條件。在目標表中符合條件的每一行,Oracle用數據源中的相應數據修改這些行。對于不滿足條件的那些行,oracle則插入數據源中相應數據。

        when matched | not matched
        用該子句通知Oracle如何對滿足或不滿足條件的結果做出相應的操作?梢允褂靡韵碌膬深愖泳。

        1.合并表
        2.外部數據插入更新
        3.用JOIN表更新

        各種情況下的
        1.合并表
        把表格T2的數據合并到表格T1里,根據結合條件,如果存在則更新,不存在則插入

         

        MERGE INTO T1

        USING T1 ON(

          T1.user_id = T2.user_id

        )

        WHEN MATCHED THEN

          UPDATE SET

                 T1.user_nm = T2.user_nm

        WHEN NOT MATCHED THEN

          INSERT

             (user_id,user_nm)

          VALUES

             (T2.user_id,T2.user_nm)


        2.外部數據插入更新

        根據外部傳進來的參數,如果存在的話,用給定的參數更新,如果不存在則插入


        MERGE INTO T1

        USER DUAL ON(

          T1.user_id = '001'

        )

        WHEN MATCHED THEN

          UPDATE SET

             T1.user_nm = 'David Vi'

        WHEN NOT MATCHED THEN

          INSERT

             (user_id, user_nm)

          VALUES

             ('001','David Vi')

        3.用JOIN表更新
        這個其實和第一個應用差不多,就是USING內部是個多個表進行結合的子表,根據多個表的結合查詢然后對對象表進行更新。

        對于第1,3應用有個問題,就是更新對象表和USING表(子表)是1:N的關系的話,無法更新。
        另外,對于第3個應用,不如用VIEW更新來的快。
         


        本文出自:億恩科技【www.endtimedelusion.com】

        服務器租用/服務器托管中國五強!虛擬主機域名注冊頂級提供商!15年品質保障!--億恩科技[ENKJ.COM]

      1. 您可能在找
      2. 億恩北京公司:
      3. 經營性ICP/ISP證:京B2-20150015
      4. 億恩鄭州公司:
      5. 經營性ICP/ISP/IDC證:豫B1.B2-20060070
      6. 億恩南昌公司:
      7. 經營性ICP/ISP證:贛B2-20080012
      8. 服務器/云主機 24小時售后服務電話:0371-60135900
      9. 虛擬主機/智能建站 24小時售后服務電話:0371-60135900
      10. 專注服務器托管17年
        掃掃關注-微信公眾號
        0371-60135900
        Copyright© 1999-2019 ENKJ All Rights Reserved 億恩科技 版權所有  地址:鄭州市高新區翠竹街1號總部企業基地億恩大廈  法律顧問:河南亞太人律師事務所郝建鋒、杜慧月律師   京公網安備41019702002023號
          0
         
         
         
         

        0371-60135900
        7*24小時客服服務熱線

         
         
        av不卡不卡在线观看_最近2018年中文字幕_亚洲欧美一区二区三区_一级A爱做片免费观看国产_日韩在线中文天天更新_伊人中文无码在线