oracle觸發器

来源:http://www.cnblogs.com/baoggg/archive/2016/12/12/6165567.html
-Advertisement-
Play Games

類型 行級觸發器: FOR EACH ROW 影響的每一行都會執行觸發器 語句級出發器 預設的模式,一句話才執行一次觸發器 觸發器不能嵌套,不能含有事務控制語句 何時觸發 Before:條件運行前 After:條件運行後 Instead of:替代觸發,作用在視圖上 創建觸發器 實例一 1.創建一個 ...


類型

行級觸發器:

  • FOR EACH ROW
    影響的每一行都會執行觸發器

語句級出發器

  • 預設的模式,一句話才執行一次觸發器
    觸發器不能嵌套,不能含有事務控制語句

何時觸發

  • Before:條件運行前
  • After:條件運行後
  • Instead of:替代觸發,作用在視圖上

創建觸發器

實例一

1.創建一個與scott下的emp表結構一樣的表emp_his,並不添加數據

create table emp_his as select * from employees where 0=1;

這種構造與現存表相同結構的表,是不會將comment帶過來的

2.然後在emp表中創建before delete類型的觸發器,
當即將刪除emp表記錄時,將相應記錄插入到emp_his中。

create or replace trigger hr.e_delete
    before delete on employees
    for each row
    begin
    insert into emp_his values(:old.employee_id,
        :old.first_name,:old.last_name,:old.email,
        :old.phone_number,:old.hire_date,:old.job_id,
        :old.salary,:old.commission_pct,:old.manager_id,
        :old.department_id);
    end e_delete;

實例二

禁止對錶emp的salary進行更改

create or replace trigger e_update
before update of salary on emp
begin
if updating then
raise_application_error(-20001,'工資不能被改動');
end if;
end;

檢驗

hr@ORCL> update emp
  2  set salary=100
  3  where employee_id<100;
update emp
       *
第 1 行出現錯誤:
ORA-20001: 工資不能被改動
ORA-06512: 在 "HR.E_UPDATE", line 3
ORA-04088: 觸發器 'HR.E_UPDATE' 執行過程中出錯


hr@ORCL>

觸發器管理

禁用觸發器

alter trigger e_delete disable;

禁用某個表上所有的觸發器

alter table emp disable all triggers;

查all_trigger表得到觸發器名字

select trigger_name,trigger_type,table_owner,table_name from all_triggers;

查看觸發器內容

select text from all_source where type='TRIGGER' and name='E_DELETE';

註意,平時在寫sql的時候不註意大小寫,但是在此處涉及到觸發器名字的時候一定要大寫

hr@ORCL> select text from all_source where type='TRIGGER' and name='E_DELETE';

TEXT
---------------------------------------------------------------------------------------------------------------------
trigger hr.e_delete
before delete on employees
for each row
begin
insert into emp_his values(:old.employee_id,
:old.first_name,:old.last_name,:old.email,
:old.phone_number,:old.hire_date,:old.job_id,
:old.salary,:old.commission_pct,:old.manager_id,
:old.department_id);

end e_delete;

已選擇11行。

hr@ORCL>

刪除觸發器

drop trigger e_delete_1;




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

-Advertisement-
Play Games
更多相關文章
  •   對於直播來說,客戶端主要做兩件事情,推流和播放。今天先講播放。 播放流程 1.拉流:伺服器已有直播內容,從指定地址進行拉取的過程。其實就是向伺服器請求數據。 2.解碼:對視屏數據進行解壓縮。 3.渲染:生成圖片的過程。視屏其實就是一張張連續的圖片進行切換,一張圖片就是一幀。幀 ...
  • ➠更多技術乾貨請戳:聽雲博客 動態鏈接 要解決空間浪費和更新困難這兩個問題最簡單的方法就是把程式的模塊相互分割開來,形成獨立的文件,而不再將它們靜態的鏈接在一起。簡單地講,就是不對那些組成程式的目標文件進行鏈接,等到程式要運行時才進行鏈接。也就是說,把鏈接過程推遲到了運行時再進行,這就是 _動態鏈接 ...
  • 示例一:實現通知欄管理 當針對相同類型的事件多次發出通知,作為開發者,應該避免使用全新的通知,這時就應該考慮更新之前通知欄的一些值來達到提醒用戶的目的。例如我們手機的簡訊系統,當不斷有新消息傳來時,我們的通知欄僅僅是更改傳來簡訊的數目,而不是對每條簡訊單獨做一個通知欄用於提示。 修改通知 可以設置一 ...
  • 今天在寫微信登錄,花了半天時間搞定、然後寫下自己的筆記,希望幫助更多的人。。。歡迎各位指教。 微信授權登錄,官方說的不是很清楚、所以導致有一部分的坑。 微信註冊應用平臺的應用簽名,下載 微信簽名生成工具 輸入項目的packageName也可以查看到。 (註意:debug、Release 一定要區分, ...
  • 在SQL Server中導入數據時,會有一個“啟用標示插入”的選項,突然間懵逼了,這到底啥意思?我選與不選這個選項,結果好像沒區別!不科學啊這,“存在即合理”,我相信這個選項肯定有它的用處,只是我不知道罷了。 於是我去查資料,在CSDN論壇里找到了可能的解釋: 1)首先:“啟用標示插入”只對標示列( ...
  • 事務 事務是作為單個邏輯工作單元執行的一系列操作。一個邏輯工作單元必須有四個屬性,稱為原子性、一致性、隔離性和持久性 (ACID) 屬性,只有這樣才能成為一個事務。 事務併發 資料庫是多個用戶(事務)共用的,當多個用戶同時訪問數據時,那麼在這種情況下就叫做併發。 事務併發下可能出現的問題 更新丟失 ...
  • oracle資料庫中,數據的增、刪、改、查,通過SQL語句實現 SQL:結構化查詢語言; 特點:不區分大小寫;字元串用單引號引起來;語句結束用分號表示結束; 行註釋,在語句的最前面加“--” 塊註釋,分別在語句的前後加 /* 和 */ SQL中常用的幾類: 一、數據定義語言 DDL:創建、修改、刪除 ...
  • 最近在入門nodejs,正好學習到瞭如何使用nodejs進行資料庫的連接,覺得比較重要,便寫一下隨筆,簡單地記錄一下 使用在安裝好node之後,我們可以使用npm命令,在項目的根目錄,安裝nodejs中的mysql模塊 在連接資料庫之前,要先引入nodejs連接處理mysql的模塊 類似php連接m ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...