當前位置:首頁 » 操作系統 » 資料庫tri

資料庫tri

發布時間: 2022-12-18 16:26:04

『壹』 Oracle資料庫中利用Trigger監控刪除數據操作

我給你寫一個。稍等,我先佔個頭坑。
請告訴我B表跟A表的關系,以及關聯欄位。
謝謝。
QQ
17369841
CREATE
OR
REPLACE
TRIGGER
TR_COPY_DATA
BEFORE
DELETE
ON
A
FOR
EACH
ROW
BEGIN
INSERT
INTO
LOGA(A的欄位1,A的欄位2,A的欄位3,delete_id,DELETE_TIME)
VALUES(:old.A的欄位1,:old.A的欄位2,:old.A的欄位3,USER,SYSDATE)
;
INSERT
INTO
LOGB
SELECT
B.*
FROM
A,B
WHERE
A.***
=
B.***
;
END
TR_COPY_DATA
;

『貳』 資料庫觸發器是什麼

觸發器是一類特殊的存儲過程,被定義為在對表或視圖發出 UPDATE、INSERT 或 DELETE 語句時自動執行。觸發器是功能強大的工具,使每個站點可以在有數據修改時自動強制執行其業務規則。觸發器可以擴展 sql Server 約束、默認值和規則的完整性檢查邏輯,但只要約束和默認值提供了全部所需的功能,就應使用約束和默認值。

表可以有多個觸發器。CREATE TRIGGER 語句可以與 FOR UPDATE、FOR INSERT 或 FOR DELETE 子句一起使用,指定觸發器專門用於特定類型的數據修改操作。當指定 FOR UPDATE 時,可以使用 IF UPDATE (column_name) 子句,指定觸發器專門用於具體某列的更新。

代碼是寫在資料庫裡面的,觸發器包含 Transact-SQL 語句,這與存儲過程十分相似。

如果你有安裝SQL SEVER,那麼你可以在SQL SEVER的幫助文檔里找到很多詳細的解析,打開查詢分析器按F1也可以打開SQL SEVER的幫助文檔。

示例
下例首先創建一個觸發器,當用戶在表 roysched 中添加或更改數據時,該觸發器向客戶端列印一條用戶定義消息。然後,使用 ALTER TRIGGER 語句使該觸發器僅對 INSERT 活動有效。該觸發器有助於提醒向表中插入行或更新行的用戶及時通知書的作者和出版商。

USE pubs
GO
CREATE TRIGGER royalty_reminder
ON roysched
WITH ENCRYPTION
FOR INSERT, UPDATE
AS RAISERROR (50009, 16, 10)

-- Now, alter the trigger.
USE pubs
GO
ALTER TRIGGER royalty_reminder
ON roysched
FOR INSERT
AS RAISERROR (50009, 16, 10)

『叄』 資料庫中觸發器的作用是什麼

觸發器是資料庫提供給程序員和數據分析員來保證數據完整性的一種機制,它是一種與數據表事件相關的特殊的存儲過程。觸發器的執行不是由程序調用,也不需要手工開啟,而是由數據表上的事件來觸發,當用戶對一個數據表進行增、刪、改操作時就會激活它執行。

觸發器可以查詢其他表,而且可以包含復雜的SQL語句。它們主要用於強制服從復雜的業務規則或要求。觸發器也可用於強制引用完整性,以便在多個表中添加、更新或刪除行時,保留在這些表之間所定義的關系。

觸發器功能強大,可以輕松可靠地實現許多復雜的功能,但也不能過於依賴觸發器,濫用觸發器會造成關系資料庫及應用程序維護困難,性能、效率低下等問題的產生,在實際問題中,要根據實際需要選擇合適的解決方案。觸發器是一種特殊的存儲過程,在插入、刪除、修改特定表中的數據時觸發執行,擁有比資料庫本身更強大的數據控制能力,其作用有以下四大方面。

1.數據安全數據安全主要是指對信息系統中的業務數據提供一種數據變更的審核機制,當其通過安全策略的審核後,允許用戶變更相關數據,否則直接拒絕數據變更的請求。

安全原理:基於資料庫的值使用戶具有操作資料庫的某種權利。

((1)可以基於時間限制用戶的操作。例如,不允許下班後和節假日修改資料庫數據。

(2)可以基於資料庫中的數據限制用戶的操作。例如,不允許股票價格的升幅一次超過10%。

2.數據審計數據審計主要是指對數據伺服器上的記錄進行變更時的一種用戶許可權的即時審查與用戶行為的全方位記錄,以便事後對數據變更過程的追溯,保證數據變更的合法性。

審計原理:跟蹤用戶對資料庫的操作。

((1)審計用戶操作資料庫的語句。

(2)把用戶對資料庫的更新寫入審計表。

3.數據約束數據約束是指對用戶的操作行為將導致業務數據與實際情況相悖的行為進行檢查約束,而不讓其發生,從而保證數據的完整性與一致性。

約束原理:對用戶操作與實際邏輯的約束檢查。

((1)實現數據完整性檢查和約束。例如,回退任何企圖買進超過自己資金的貨物。

(2)提供可變的預設值。

4.數據連環更新數據連環更新是指當對數據進行更新操作時,將所有與此數據相關聯的數據作聯合的更新操作,以保證數據的完整性與一致性。

連環更新原理:對關聯數據作聯合更新操作。

((1)修改或刪除時級聯修改或刪除其他表中與之匹配的行。

(2)修改或刪除時把其他表中與之匹配的行設成NULL值。

(3)修改或刪除時把其他表中與之匹配的行級聯設成預設值。

『肆』 資料庫中Triggers的作用已經用法

TRIGGERS表提供了關於觸發程序的信息。

必須有SUPER許可權才能查看該表。

TRIGGER_SCHEMA和TRIGGER_NAME列中分別含有相應資料庫的名稱以及觸發程序的名稱,在該資料庫中,含有該觸發程序。

MySQL 5.1包含對觸發程序的支持。觸發程序是與表有關的命名資料庫對象,當表上出現特定事件時,將激活該對象。例如,下述語句將創建1個表和1個INSERT觸發程序。觸發程序將插入表中某一列的值加在一起:

mysql> CREATE TABLE account (acct_num INT, amount DECIMAL(10,2));
mysql> CREATE TRIGGER ins_sum BEFORE INSERT ON account
-> FOR EACH ROW SET @sum = @sum + NEW.amount;

CREATE TRIGGER語法
CREATE TRIGGER trigger_name trigger_time trigger_event
ON tbl_name FOR EACH ROW trigger_stmt
觸發程序是與表有關的命名資料庫對象,當表上出現特定事件時,將激活該對象。

觸發程序與命名為tbl_name的表相關。tbl_name必須引用永久性表。不能將觸發程序與TEMPORARY表或視圖關聯起來。

trigger_time是觸發程序的動作時間。它可以是BEFORE或AFTER,以指明觸發程序是在激活它的語句之前或之後觸發。

trigger_event指明了激活觸發程序的語句的類型。trigger_event可以是下述值之一:

· INSERT:將新行插入表時激活觸發程序,例如,通過INSERT、LOAD DATA和REPLACE語句。

· UPDATE:更改某一行時激活觸發程序,例如,通過UPDATE語句。

· DELETE:從表中刪除某一行時激活觸發程序,例如,通過DELETE和REPLACE語句。

請注意,trigger_event與以表操作方式激活觸發程序的SQL語句並不很類似,這點很重要。例如,關於INSERT的BEFORE觸發程序不僅能被INSERT語句激活,也能被LOAD DATA語句激活。

可能會造成混淆的例子之一是INSERT INTO .. ON DUPLICATE UPDATE ...語法:BEFORE INSERT觸發程序對於每一行將激活,後跟AFTER INSERT觸發程序,或BEFORE UPDATE和AFTER UPDATE觸發程序,具體情況取決於行上是否有重復鍵。

對於具有相同觸發程序動作時間和事件的給定表,不能有兩個觸發程序。例如,對於某一表,不能有兩個BEFORE UPDATE觸發程序。但可以有1個BEFORE UPDATE觸發程序和1個BEFORE INSERT觸發程序,或1個BEFORE UPDATE觸發程序和1個AFTER UPDATE觸發程序。

DROP TRIGGER語法
DROP TRIGGER [schema_name.]trigger_name
舍棄觸發程序。方案名稱(schema_name)是可選的。如果省略了schema(方案),將從當前方案中舍棄觸發程序。

『伍』 資料庫中trigger有什麼作用

觸發器,一種特殊的存儲過程,可以利用它監聽insist,update,delete等操作時,執行特定的SQL語句。

『陸』 oracle中的trigger有幾種啊

ORACLE資料庫有四種觸發器,分別是DML、Instead-of、DDL、DB觸發器,一般的應用系統中都是用到DML、Instead-of觸發器,DDL、DB兩種觸發器是DBA管理資料庫用得比較多

四種觸發器分別有不同的作用
一、DML觸發器:當發出UPDATE、INSERT、DELETE命令就可以觸發已定義好的DML觸發器,是最簡單和常用的一種觸發器
語法:
create or replace trigger trigger_name
after|before insert|update|delete
on table_name
for each row
二、Instead-of觸發器:當向一個由多個表聯接成的視圖作DML操作時,一般情況下是不允許的,這時候就可以用Instead-of觸發器來解決這種問題(在觸發器寫代碼分別對各表作相應DML操作),語法是這樣的:
create or replace trigger trigger_name
instead of insert|update|delete
on view_name
for each row
三、DDL觸發器:當發出CREATE、ALTER、DROP、TRUNCATE命令時會觸發已定義好的DDL觸發器,這種觸發器可以用來監控某個用戶或整個資料庫的所有對象的結構變化
語法:
create or replace trigger trigger_name
before|after create|alter|drop|truncate
on schema|database
例:
--禁止用CREATE、ALTER、DROP、TRUNCATE命令操作APPS用戶的對象
create or replace trigger apps_no_ddl
before create or alter or drop or truncate
on apps
begin
raise_application_error(-20001,'不允許用DDL操作APPS用戶的對象');
end;
四、DB事件觸發器:當STARTUP、SHUTDOWN、LOGON、LOGOFF資料庫時就會觸發DB事件觸發器,這種觸發器可以用來監控資料庫什麼時候關閉/打,或者用戶的LOGON/LOGOFF資料庫情況
語法:
create or replace trigger trigger_name
before|after startup|shutdown|logon|logoff
on database
例:
--記錄資料庫關閉的時間(shutdown類型要用關鍵字before,startup用after)
create or replace trigger db_shutdown
before shutdown
on database
begin
insert into test_tbl(log_event) values('db shutdown at '||to_char(sysdate,'yyyy-mm-dd hh24:mi:ss'));
commit;
end;
--記錄用戶LOGON時間(logoff類型要用關鍵字before,logon用after)
create or replace trigger user_logon_db
after logon
on database
begin
insert into test_tbl(username,logon_time) values(user,to_char(sysdate,'yyyy-mm-dd hh24:mi:ss'));
commit;
end;
注意:要創建DDL和DB事件這兩種觸發器必須要有DBA的許可權才行

『柒』 資料庫中的「觸發器」是什麼意思

在SQL中,名詞觸發器指「在資料庫中為響應一個特殊表格中的某些事件而自動執行的程序代碼。」(Wikipedia)說得簡單一些,它是在一個特殊的資料庫事件,如INSERT或DELETE發生時,自動激活的一段代碼。觸發器可方便地用於日誌記錄、對單個表格到其他鏈接式表格進行自動的「層疊式」更改、或保證對表格關系進行自動更新。當一個新整數值增加到資料庫域中時,自動更新運行的總數的代碼段是一個觸發器。自動記錄對一個特殊資料庫表格所作更改的SQL命令塊也是一個觸發器實例。
參考:
http://www.nmzol.com/ns/2007/200705/2007-05-05/ns_20070505214010_16672.html

『捌』 資料庫的觸發器怎麼進行高級操作

1.new與old在資料庫的觸發器中經常會用到更新前的值和更新後的值,所以掌握new和old的語法很重要。

old:表示操作執行前的數據行。

new:表示操作執行後的數據行。

一User數據表如圖User數據表所示,若執行以下更新操作語句:updateUsersetscore=80whereuser_id=1

User數據表

則在此操作中,old表示未執行update語句前user_id=1這行記錄;而new表示執行update語句後user_id=1這行記錄。

從上面的表述中可知,new與old均表示某一行記錄,old所表示的是寫操作發生前的這一行舊數據,new則表示寫操作發生後的這一行新的數據。正因如此,可以把new與old看作面向對象編程裡面的一個對象或實例,與面向對象的方式類似,可用new.欄位名或old.欄位名的方式進行存取值。

old.欄位名:表示未執行操作前的該行對應的某欄位值。

new.欄位名:表示執行操作後的該行對應的某欄位值。

在上面User表的update操作中:old.score=60,表示update操作前score欄位的舊值是60。

new.score=80,表示update操作後score欄位的新值是80。

如果要使用new語句進行賦值,只能在before類型的觸發器中使用,不能在after類型的觸發器中使用。

更新操作前使用before先賦值,再插入資料庫中。如以下語句是正確的:.金額=0;END更新操作後,不能在after中用new賦值,因為操作已經結束,只能讀取內容。如以下語句是錯誤的:.金額=0;ENDnew與old的區別:前者可在before觸發器中賦值、取值,也可在after觸發器中取值;

後者只能用於取值,因為賦值沒有意義。

注意:INSERT語句,只有new合法;

DELETE語句,只有old才合法;

UPDATE語句,可以同時使用new和old。

2.before與afterbefore與after表示觸發器觸發的時間點是在寫操作開始之前,還是在寫操作完成後,正因為它們有時間點先後的問題,因此它們的功能與使用場合有非常大的差別。

(1)before((1)先完成觸發操作,再執行業務數據的增刪改。

(2)觸發的語句先於監視的業務語句。

(3)有機會影響即將發生的操作。

2)after((1)先完成業務數據的增刪改,再觸發。

(2)觸發的語句晚於監視的業務語句。

(3)無法影響前面的增刪改動作。

3.異常處理MySQL現有版本中不支持自定義異常,當某處需要拋出異常時,可拋出一個系統異常(類似運行異常)。如故意往不存在的表中插入數據等方式來觸發系統異常的拋出,當異常拋出時,本次正在執行的所有操作會終止執行,並回滾所有數據到操作發生前的狀態。

在觸發器中,需要拋出異常的場景有很多,以下兩個方面較為普遍:((1)新進來的數據不符合業務邏輯。

例如,①倉庫最大商品庫存數為10,訂單要求一次性購買數量20。

②銀行賬戶上只有50元,想要支付100元的賬單。

(2)許可權不足,不允許操作。

例如,①普通用戶通過非法途徑操作核心資源表。

②在非工作日修改業務數據。4.觸發器案例用mytab.sql腳本創建表環境,然後用下面語句創建觸發器。當往mytab表添加記錄時,觸發器中將拋出異常,導致所有操作終止,並回滾所有操作的數據。

DELIMITER//DROPTRIGGERIFEXISTSt_exception_trigger;CREATETRIGGERt_exception_--tab3表不存在

『玖』 資料庫觸發器有什麼作用

觸發器的作用:

自動計算數據值,如果數據的值達到了一定的要求,則進行特定的處理。

同步實時地復製表中的數據。

實現復雜的非標準的資料庫相關完整性規則。

可在寫入數據表前,強制檢驗或轉換數據。

觸發器發生錯誤時,異動的結果會被撤銷。

部分資料庫管理系統可以針對數據定義語言(DDL)使用觸發器,稱為DDL觸發器。

可依照特定的情況,替換異動的指令 (INSTEAD OF)。


(9)資料庫tri擴展閱讀:

分類

SQL Server 包括三種常規類型的觸發器:DML 觸發器、DDL 觸發器和登錄觸發器。

DML觸發器

當資料庫中表中的數據發生變化時,包括insert,update,delete任意操作,如果我們對該表寫了對應的DML觸發器,那麼該觸發器自動執行。

DML觸發器的主要作用在於強制執行業 務規則,以及擴展Sql Server約束,默認值等。因為我們知道約束只能約束同一個表中的數據,而觸發器中則可以執行任意Sql命令。

DDL觸發器

它是Sql Server2005新增的觸發器,主要用於審核與規范對資料庫中表,觸發器,視圖等結構上的操作。比如在修改表,修改列,新增表,新增列等。

它在資料庫結構發生變化時執行,我們主要用它來記錄資料庫的修改過程,以及限製程序員對資料庫的修改,比如不允許刪除某些指定表等。

登錄觸發器

登錄觸發器將為響應 LOGIN 事件而激發存儲過程。與 SQL Server 實例建立用戶會話時將引發此事件。登錄觸發器將在登錄的身份驗證階段完成之後且用戶會話實際建立之前激發。

因此,來自觸發器內部且通常將到達用戶的所有消息(例如錯誤消息和來自 PRINT 語句的消息)會傳送到 SQL Server 錯誤日誌。如果身份驗證失敗,將不激發登錄觸發器。

參考資料來源:網路-觸發器

『拾』 SQL中觸發器有什麼作用

觸發器(trigger)是SQL server 提供給程序員和數據分析員來保證數據完整性的一種方法,它是與表事件相關的特殊的存儲過程,它的執行不是由程序調用,也不是手工啟動,而是由事件來觸發,比如當對一個表進行操作( insert,delete, update)時就會激活它執行。觸發器經常用於加強數據的完整性約束和業務規則等。 觸發器可以從 DBA_TRIGGERS ,USER_TRIGGERS 數據字典中查到。SQL3的觸發器是一個能由系統自動執行對資料庫修改的語句。x0dx0a 觸發器與存儲過程的唯一區別是觸發器不能執行EXECUTE語句調用,而是在用戶執行Transact-SQL語句時自動觸發執行。x0dx0a 觸發器可以查詢其他表,而且可以包含復雜的SQL語句。它們主要用於強制服從復雜的業務規則或要求。例如:您可以根據客戶當前的帳戶狀態,控制是否允許插入新訂單。x0dx0a觸發器也可用於強制引用完整性,以便在多個表中添加、更新或刪除行時,保留在這些表之間所定義的關系。然而,強制引用完整性的最好方法是在相關表中定義主鍵和外鍵約束。如果使用資料庫關系圖,則可以在表之間創建關系以自動創建外鍵約束。x0dx0a SQL Server 包括三種常規類型的觸發器:DML 觸發器、DDL 觸發器和登錄觸發器。x0dx0a 語法為:x0dx0a CREATE TRIGGER ``.``x0dx0a < [ BEFORE | AFTER ] > < [ INSERT | UPDATE | DELETE ] >x0dx0a ON [dbo] //dbo代表該表的所有者x0dx0a FOR EACH ROWx0dx0a BEGINx0dx0a --do somethingx0dx0a ENDx0dx0a 觸發器可通過資料庫中的相關表實現級聯更改,不過,通過級聯引用完整性約束可以更有效地執行這些更改。觸發器可以強制比用CHECK約束定義的約束更為復雜的約束。與 CHECK 約束不同,觸發器可以引用其它表中的列。例如,觸發器可以使用另一個表中的 SELECT 比較插入或更新的數據,以及執行其它操作,如修改數據或顯示用戶定義錯誤信息。觸發器也可以評估數據修改前後的表狀態,並根據其差異採取對策。一個表中的多個同類觸發器(INSERT、UPDATE 或 DELETE)允許採取多個不同的對策以響應同一個修改語句。x0dx0a 約束和觸發器在特殊情況下各有優勢。觸發器的主要好處在於它們可以包含使用 Transact-SQL 代碼的復雜處理邏輯。因此,觸發器可以支持約束的所有功能;但它在所給出的功能上並不總是最好的方法。實體完整性總應在最低級別上通過索引進行強制,這些索引或是 PRIMARY KEY 和 UNIQUE 約束的一部分,或是在約束之外獨立創建的。假設功能可以滿足應用程序的功能需求,域完整性應通過 CHECK 約束進行強制,而引用完整性(RI) 則應通過 FOREIGN KEY 約束進行強制。在約束所支持的功能無法滿足應用程序的功能要求時,觸發器就極為有用。x0dx0a CHECK 約束只能根據邏輯表達式或同一表中的另一列來驗證列值。如果應用程序要求根據另一個表中的列驗證列值,則必須使用觸發器。約束只能通過標準的系統錯誤信息傳遞錯誤信息。如果應用程序要求使用(或能從中獲益)自定義信息和較為復雜的錯誤處理,則必須使用觸發器。x0dx0a 觸發器可通過資料庫中的相關表實現級聯更改;不過,通過級聯引用完整性約束可以更有效地執行這些更改。觸發器可以禁止或回滾違反引用完整性的更改,從而取消所嘗試的數據修改。當更改外鍵且新值與主鍵不匹配時,此類觸發器就可能發生作用。例如,可以在 titleauthor.title_id 上創建一個插入觸發器,使它在新值與 titles.title_id 中的某個值不匹配時回滾一個插入。不過,通常使用 FOREIGN KEY 來達到這個目的。x0dx0a 如果觸發器表上存在約束,則在 INSTEAD OF 觸發器執行後但在 AFTER 觸發器執行前檢查這些約束。如果約束破壞,則回滾 INSTEAD OF 觸發器操作並且不執行 AFTER 觸發器。x0dx0a實例1:insert觸發器x0dx0acreate trigger tri_insertx0dx0aon studentx0dx0afor insertx0dx0aasx0dx0adeclare @student_id char(10)x0dx0aselect @student_id=s.student_id fromx0dx0astudent s inner join inserted ix0dx0aon s.student_id=i.student_idx0dx0aif @student_id=�'x0dx0abeginx0dx0araiserror('不能插入1的學號!',16,8)x0dx0arollback tranx0dx0aendx0dx0agox0dx0a實例2:update觸發器x0dx0acreate trigger tri_updatex0dx0aon studentx0dx0afor updatex0dx0aasx0dx0aif update(student_id)x0dx0abeginx0dx0araiserror('學號不能修改!',16,8)x0dx0arollback tranx0dx0aendx0dx0agox0dx0a實例3:delete觸發器示x0dx0acreate trigger tri_deletex0dx0aon studentx0dx0afor deletex0dx0aasx0dx0adeclare @student_id varchar(10)x0dx0aselect @student_id=student_id from deletedx0dx0aif @student_id='admin'x0dx0abeginx0dx0araiserror('錯誤',16,8)x0dx0arollback tranx0dx0aend

熱點內容
微博視頻高清上傳設置 發布:2025-05-14 16:38:41 瀏覽:548
資料庫圖書管理設計 發布:2025-05-14 16:33:52 瀏覽:376
php開發的網頁 發布:2025-05-14 16:22:03 瀏覽:477
伺服器內存跑滿了怎麼回事 發布:2025-05-14 16:21:16 瀏覽:224
微信qq音樂緩存 發布:2025-05-14 16:16:16 瀏覽:469
c語言回收內存 發布:2025-05-14 16:16:08 瀏覽:144
2021國產安卓頂級旗艦買哪個 發布:2025-05-14 16:15:36 瀏覽:300
linux自學視頻 發布:2025-05-14 16:14:49 瀏覽:256
我的世界伺服器崩了重啟 發布:2025-05-14 16:09:37 瀏覽:45
android深拷貝 發布:2025-05-14 16:09:35 瀏覽:154