5. Oracle之存儲過程和MERGE INTO語句

来源:https://www.cnblogs.com/Smileing/archive/2018/12/03/10058248.html
-Advertisement-
Play Games

一、MERGE INTO語句 1、merge into語句的功能:我們操作資料庫的時候,有時候會遇到insert或者Update這種需求。我們操縱代碼時至少需要寫一個插入語句和更新語句並且還得單獨寫方法效驗數據是否存在,這種操作完全可以用merge into語句代替,不僅省時省力而且條理更清晰,一個 ...


一、MERGE INTO語句

  1、merge into語句的功能:我們操作資料庫的時候,有時候會遇到insert或者Update這種需求。我們操縱代碼時至少需要寫一個插入語句和更新語句並且還得單獨寫方法效驗數據是否存在,這種操作完全可以用merge into語句代替,不僅省時省力而且條理更清晰,一個SQL語句直接完成插入,如果有相同主鍵進行更新操作。

使用場景:判斷B表和A表是否滿足ON中條件,如果滿足則用B表去更新A表,如果不滿足,則將B表數據插入A表或者更多的操作。

  2、具體SQL:下邊sql是我在工作中最常使用的,功能是對介面表(表B)中通過批次ID查到的合同進行對正式表(表A)插入和更新。除此之外,還可以根據你的想實現功能進行各種條件更新和插入。只update或者只insert,帶條件的update或帶條件的insert,全插入insert實現,帶delete的update(覺得可以用3來實現)

MERGE INTO後是更新的表,USING是對介面表進行篩選,(如果有重覆數據,僅選取一行插入,用ORDER BY 控制)。ON中是具體的條件(表中標識欄位,欄位編碼)滿足執行 WHEN MATCHED THEN 下的語句
不滿足則執行WHEN NOT MATCHED THEN 後語句:
MERGE INTO TableA A 
USING (
(SELECT L.*,
ROW_NUMBER() OVER(PARTITION BY T.FLEX_VALUE ORDER BY 1) AS RN
FROM TABLEB L
WHERE T.BATCH_ID = #{batchId} ) L
AND L.RN = 1 ) B
ON ( A.FLEX_VALUE = B.FLEX_VALUE )
WHEN MATCHED THEN
UPDATE
A.FLEX_VALUE_SET_NAME = B.FLEX_VALUE_SET_NAME,
A.VALIDATION_TYPE = B.VALIDATION_TYPE,
WHEN NOT MATCHED THEN
INSERT (
A.FLEX_VALUE_SET_NAME = B.FLEX_VALUE_SET_NAME,
A.VALIDATION_TYPE = B.VALIDATION_TYPE)

二、ORACLE的存儲過程

  1、定義:存儲過程(Stored Procedure):就是一組用於完成特定資料庫功能的SQL語句集,該SQL語句集經過,編譯後存儲在資料庫系統中。在使用時候,用戶通過指定已經定義的存儲過程名字並給出相應的存儲過程參數,來調用並執行它,從而完成一個或一系列的資料庫操作。

  2、創建:Oracle存儲過程包含三部分:過程聲明,執行過程部分,存儲過程異常。

我在工作中常用的一個存儲過程結構如下:

--存儲過程校驗信息,三個入參,一個輸入批次。輸出分別是錯誤編碼,和錯誤信息。

  PROCEDURE VALIDATE_ARCHIVE_ITF(P_BATCHID IN VARCHAR2,
                    P_FLAG OUT NUMBER,
                    P_MSG OUT VARCHAR2) IS
         CURSOR CMS_ARCHIVE_ITF(BATCHID VARCHAR2) IS
      SELECT ROWID,
        CONTRACT_NO,
        ARCHIVE_STUTAS,
        ERROR_INFO,
        ARC_TIME
      FROM CMS_ARCHIVE_IFT CAI
      WHERE CAI.BATCH_ID = BATCHID;
  L_ERROR_MSG VARCHAR2(255); --定義變數錯誤信息
  L_TENANT_ID VARCHAR2(255);--定義變數租戶ID
  L_CONTRACT_SERIAL_NO VARCHAR2(255);--定義變數
BEGIN
    FOR RET IN CMS_ARCHIVE_ITF(P_BATCHID) LOOP
    L_ERROR_MSG := NULL;--給傳入三個參數賦預設值
    P_FLAG := 1;
    P_MSG := NULL;

  --對輸入欄位非空效驗  
  IF (RET.ARC_TIME IS NULL OR RET.ARC_TIME = '') THEN
    L_ERROR_MSG := L_ERROR_MSG || 'LAST_UPDATE_DATE不能為空;';
  END IF;
  --判斷非空校驗是否成功,不成功繼續繼續下一個。如果有錯誤更新介面表
  IF L_ERROR_MSG IS NOT NULL THEN
  P_FLAG := -99;
  UPDATE CMS_ARCHIVE_IFT
  SET ERROR_CODE = '01', ERROR_MSG = L_ERROR_MSG
  WHERE ROWID = RET.ROWID;
  CONTINUE;
  END IF;
  --如果成功通過條件效驗
  IF P_FLAG = 1 THEN
  BEGIN
  INSERT INTO CMS_ARCHIVE_INFO
    (TENANT_ID,
    CONTRACT_ID,
    ARCHIVE_ID)
    VALUES
      ( RET.TENANT_ID,
       (SELECT CONTRACT_ID
        FROM CMS_CONTRACT_INFO
        WHERE CONTRACT_NO = RET.CONTRACT_NO),
        SYS_GUID() )

      EXCEPTION--異常信息
      WHEN OTHERS THEN
      DBMS_OUTPUT.PUT_LINE(SUBSTR(SQLERRM, 1, 200));
      P_FLAG := -99;
      P_MSG := SUBSTR(SQLERRM, 1, 200);
      END;
      END IF;
      END LOOP;
      END;

  


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • ***********模糊查詢*********/ 關鍵字: like (!!!!字元串類型) in (,,) 匹配()內的某個具體值(括弧里可以寫多個值) between... and.. 在某兩個值的區間範圍中(前後都包括,小的寫前面,大的寫後面) **********通配符********/ ...
  • 本文力在從oracle的基礎出發,從oracle的基礎結束,從資料庫的連接、用戶管理、sqlplus使用、plsql工具、存儲過程、函數、包、觸發器等一個DBA經常進行的操作與維護方面入手,旨在從這條最淺顯易懂的學習道路上,瞭解oracle的日常使用。相信對於初學者是個不錯的選擇,也希望自己的這篇整... ...
  • 一. 概述 Redis伺服器是可以與多個客戶端建立網路連接,每個客戶端可以向伺服器發送命令請求,而伺服器則接收並處理客戶端發送的命令請求,並向客戶端返回命令回覆。通過使用I/O多路復用技術實現的文件事件處理器,Redis伺服器使用單進程單線程的方式來處理命令請求,並與多個客戶端進行網路通信。 1.1 ...
  • 本文由QQ大數據發表 最朴素的做法 在大多數情況下,大量的重覆文本一般不會是什麼好事情,比如互相抄襲的新聞,群發的垃圾簡訊,鋪天蓋地的廣告文案等,這些都會造成網路內容的同質化並加重資料庫的存儲負擔,更糟糕的是降低了文本內容的質量。因此需要一種準確而高效率的文本去重演算法。而最朴素的做法就是將所有文本進 ...
  • CREATE OR REPLACE TYPE ty_tbl_str_split IS TABLE OF ty_row_str_split;CREATE OR REPLACE TYPE ty_row_str_split as object (strValue VARCHAR2(4000));CREAT ...
  • 首先進去mysql。打開電腦命令提示符(cmd);輸入mysql -uroot -p 代表的意思是使用ruser使用者root的方式,打開mysql,-p代表password,如果有的話,回車之後再輸入密碼在回車就進去mysql環境了 在>提示符符號後面就可以輸入mysql語句來進行mysql操作了 ...
  • 學習目標 理解MongoDb的特點和體繫結構 掌握常用的MongoDB命令 MongoDB是一種介於關係資料庫和非關係資料庫中的一種資料庫.它支持的數據結構非常鬆散,類似於JSON的BJSOn格式,所以可以存儲比較複雜的數據類型。 MongoDB特點 面向集合存儲,易於存儲對象類型的數據 模式自由 ...
  • 資料庫事務是資料庫運行中的邏輯工作單位,單個邏輯工作單元所執行的一系列操作,要麼都執行,要麼都不執行。例如銀行取款事務分為2個步驟(1)存摺減款(2)提取現金,2個步驟必須同時完成或者都不完成。 資料庫事務的四大特性(ACID): (1) 原子性(Atomicity): 事務的原子性指的是,事務中包 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...