Oracle觸發器簡單入門記錄

来源:https://www.cnblogs.com/eleven258/archive/2018/04/25/8940490.html
-Advertisement-
Play Games

寫在前面: 最近,老項目新增了日報優化的需求,麗姐讓我用觸發器去實現當數據插入或者更新的時候,實現對日報表數據更新操作。嗯嗯嗯呢,之前學習資料庫的時候,有碰到過觸發器,但都是一跳而過,也沒怎麼去真正的實踐,這次就權當再次去學習吧~~ 1.觸發器實例: 上面的觸發器例子,只是一個框架,並不能執行,這裡 ...


寫在前面:

  最近,老項目新增了日報優化的需求,麗姐讓我用觸發器去實現當數據插入或者更新的時候,實現對日報表數據更新操作。嗯嗯嗯呢,之前學習資料庫的時候,有碰到過觸發器,但都是一跳而過,也沒怎麼去真正的實踐,這次就權當再次去學習吧~~

 

1.觸發器實例:

--創建觸發器
create or replace trigger test_trigger2
--觸發器是在insert或update動作之後執行的
after insert or update
--作用於dms.kqm_leaveapply表的每一行
on dms.kqm_leaveapply
--這裡預設為new ,old 怕與其他變數有衝突,則做了修改
referencing new as new_val old as old_val
for each row
--觸發器限制條件  
when (new_val.statusname = '核准')
--觸發器描述語句中,新數據使用new_val進行引用,在下麵的操作語句中,新數據使用:new_val進行引用

declare  --聲明變數
   st_str varchar2(100);
   et_str varchar2(100);

   time1 number;
   time2 number;
   ......
begin
   ......

   --查詢結果集,進行遍歷

   for daylist in (
     --查詢出指定時間段內的所有日期
     select to_char(:new_val.startdate+rownum-1,'yyyymmdd') as dd
     from dual
     connect by rownum <=
          trunc(:new_val.enddate - :new_val.startdate)+1
   )
   loop
     
        --寫要進行操作的邏輯
        ......
         --更新另外一張表的數據 
         update dms.d_dailyreport_t d set d.shours =  (8 - ItemValue)
         where d.personcode = :new_val.workno and  to_char(d.ftime,'yyyy/mm/dd') like to_char(daylist.dd,'yyyy/mm/dd')  ;

   end loop;
  
     --substr()數據截取
     st_str :=substr(:new_val.starttime,1,2) || substr(:new_val.starttime,4,2) ;
     et_str := substr(:new_val.endtime,1,2) || substr(:new_val.endtime,4,2) ;
     time1 := to_number(st_str);
     time2 := to_number(et_str);

     if(Item_m<0) then
         Item_m := Item_m *(-1);
         tHour := tHour -1;
     end if;

end test_trigger2;

  上面的觸發器例子,只是一個框架,並不能執行,這裡只做簡單的記錄,網上的例子有很多,稍微看一下就能簡單入門了,這裡就不多做記錄與說明瞭~~

 

 

    


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

-Advertisement-
Play Games
更多相關文章
  • Oozie Email Action 配置 Shell Action 可以用來為oozie中的流程任務發送郵件,Email Action 必須配置 to收件人,cc收件人(可選),郵件主題,郵件內容,多個收件人可以使用,分割收件人地址。Email Action是同步執行的,流程任務必須等當前節點的郵 ...
  • row_number的用途非常廣泛,排序最好用它,它會為查詢出來的每一行記錄生成一個序號,依次排序且不會重覆,註意使用row_number函數時必須要用over子句選擇對某一列進行排序才能生成序號。 rank函數用於返回結果集的分區內每行的排名,行的排名是相關行之前的排名數加一。簡單來說rank函數 ...
  • 涉及到sock連接的問題。 為了測試MySQL的某些個特性,在一個機器上安裝了多個MySQL的實例,如下截圖,有兩個實例,一個埠是8000,一個埠是8001。在使用mysql -uroot -p -P8001連接至埠號為8001的MySQL實例的時候,show variables like ' ...
  • 今天安裝完Mysql後,開啟發生了錯誤: 1、打開相應文件夾,查看錯誤信息: 2、打開錯誤信息文件,查看錯誤原因是:Plugin 'FEDERATED' is disabled. /usr/sbin/mysqld: Table 'mysql.plugin' doesn't exist 3、‘mysq ...
  • 本文目錄: 1.1 視窗和開窗函數簡介 1.2 OVER()語法和執行位置 1.3 row_number()對分區排名 1.4 rank()和dense_rank() 1.5 percent_rank()和cume_dist() 1.6 ntile()數據分組 1.7 取相鄰行數據:lag()函數和 ...
  • 想用linux虛擬機裝一個oracle,中間遇到的坑太多了,最後總算是安裝好了,一定要寫個全面的教程出來。 話不多說 通用編輯命令: vi test.txt #進入編輯模式 編輯完成後按ESC退出編輯模式 :wq 回車 保存編輯的文件 1.設置linux開機自動打開網路連接,不打開網路連接Secur ...
  • Mysql遠程連接 Host * is not allowed to connect to this MySQL server 解決辦法:在本機登入mysql後,選擇用戶,修改你遠程鏈接的用戶的主機,從 localhost 改為 % ...
  • SQL中的LEFT RIGHT INNER JOIN的區別及學習,僅供參考,如有錯誤,歡迎糾正。 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...