激情五月天婷婷,亚洲愉拍一区二区三区,日韩视频一区,a√天堂中文官网8

<ul id="buwfs"><strike id="buwfs"><strong id="buwfs"></strong></strike></ul>
    <output id="buwfs"></output>
  • <dfn id="buwfs"><source id="buwfs"></source></dfn>
      <dfn id="buwfs"><td id="buwfs"></td></dfn>
      <div id="buwfs"><small id="buwfs"></small></div>
      <dfn id="buwfs"><source id="buwfs"></source></dfn>
      1. <dfn id="buwfs"><td id="buwfs"></td></dfn>
        始創(chuàng)于2000年 股票代碼:831685
        咨詢熱線:0371-60135900 注冊(cè)有禮 登錄
        • 掛牌上市企業(yè)
        • 60秒人工響應(yīng)
        • 99.99%連通率
        • 7*24h人工
        • 故障100倍補(bǔ)償
        全部產(chǎn)品
        您的位置: 網(wǎng)站首頁(yè) > 幫助中心>文章內(nèi)容

        Oracle中MERGE INTO的用法

        發(fā)布時(shí)間:  2012/8/30 16:45:57

        自從版本9i之后,對(duì)于“有則更新,無(wú)則插入”有了一個(gè)新的用法,不需要再執(zhí)行2次SQL了。


        merge 命令可以用來(lái)用一個(gè)表中的數(shù)據(jù)來(lái)修改或者插入到另一個(gè)表。插入或者修改的操作取決于on子句的條件。MERGE INTO本來(lái)應(yīng)該是用來(lái)合并表的,不過(guò)因?yàn)槠涮匦,根?jù)用途不同可以用在以下場(chǎng)合:
        -
         

        關(guān)鍵字、參數(shù)

        into 子句
        在into子句中指定所要修改或者插入數(shù)據(jù)的目標(biāo)表

        using 子句
        在using子句中指定用來(lái)修改或者插入的數(shù)據(jù)源。數(shù)據(jù)源可以是表、視圖或者一個(gè)子查詢語(yǔ)句。

        on 子句
        在on子句中指定執(zhí)行插入或者修改的滿足條件。在目標(biāo)表中符合條件的每一行,Oracle用數(shù)據(jù)源中的相應(yīng)數(shù)據(jù)修改這些行。對(duì)于不滿足條件的那些行,oracle則插入數(shù)據(jù)源中相應(yīng)數(shù)據(jù)。

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

        1.合并表
        2.外部數(shù)據(jù)插入更新
        3.用JOIN表更新

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

         

        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.外部數(shù)據(jù)插入更新

        根據(jù)外部傳進(jìn)來(lái)的參數(shù),如果存在的話,用給定的參數(shù)更新,如果不存在則插入


        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表更新
        這個(gè)其實(shí)和第一個(gè)應(yīng)用差不多,就是USING內(nèi)部是個(gè)多個(gè)表進(jìn)行結(jié)合的子表,根據(jù)多個(gè)表的結(jié)合查詢?nèi)缓髮?duì)對(duì)象表進(jìn)行更新。

        對(duì)于第1,3應(yīng)用有個(gè)問(wèn)題,就是更新對(duì)象表和USING表(子表)是1:N的關(guān)系的話,無(wú)法更新。
        另外,對(duì)于第3個(gè)應(yīng)用,不如用VIEW更新來(lái)的快。
         


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

        服務(wù)器租用/服務(wù)器托管中國(guó)五強(qiáng)!虛擬主機(jī)域名注冊(cè)頂級(jí)提供商!15年品質(zhì)保障!--億恩科技[ENKJ.COM]

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

        0371-60135900
        7*24小時(shí)客服服務(wù)熱線