A. 連鎖葯店mysql觸發器怎麼寫
語法說明如下。
1) 觸發器名
觸發器的名稱,觸發器在當前資料庫中必須具有唯一的名稱。如果要在某個特定資料庫中創建,名稱前面應該加上資料庫的名稱。
2) INSERT | UPDATE | DELETE
觸發事件,用於指定激活觸發器的語句的種類。
注意:三種觸發器的執行時間如下。INSERT:將新行插入表時激活觸發器。例如,INSERT 的 BEFORE 觸發器不僅能被 MySQL 的 INSERT 語句激活,也能被 LOAD DATA 語句激活。DELETE: 從表中刪除某一行數據時激活觸發器,例如 DELETE 和 REPLACE 語句。UPDATE:更改表中某一行數據時激活觸發器,例如 UPDATE 語句。
3) BEFORE | AFTER
BEFORE 和 AFTER,觸發器被觸發的時刻,表示觸發器是在激活它的語句之前或之後觸發。若希望驗證新數據是否滿足條件,則使用 BEFORE 選項;若希望在激活觸發器的語句執行之後完成幾個或更多的改變,則通常使用 AFTER 選項。
4) 表名
與觸發器相關聯的表名,此表必須是永久性表,不能將觸發器與臨時表或視圖關聯起來。在該表上觸發事件發生時才會激活觸發器。同一個表不能擁有兩個具有相同觸發時刻和事件的觸發器。例如,對於一張數據表,不能同時有兩個 BEFORE UPDATE 觸發器,但可以有一個 BEFORE UPDATE 觸發器和一個 BEFORE INSERT 觸發器,或一個 BEFORE UPDATE 觸發器和一個 AFTER UPDATE 觸發器。
5) 觸發器主體
觸發器動作主體,包含觸發器激活時將要執行的 MySQL 語句。如果要執行多個語句,可使用 BEGIN…END 復合語句結構。
B. 什麼是觸發器
SQL觸發器實例1定義: 何為觸發器?在SQL Server裡面也就是對某一個表的一定的操作,觸發某種條件,從而執行的一段程序。觸發器是一個特殊的存儲過程。
常見的觸發器有三種:分別應用於Insert , Update , Delete 事件。
我為什麼要使用觸發器?比如,這么兩個表:
Create Table Student( --學生表
StudentID int primary key, --學號
....
)
Create Table BorrowRecord( --學生借書記錄表
BorrowRecord int identity(1,1), --流水號
StudentID int , --學號
BorrowDate datetime, --借出時間
ReturnDAte Datetime, --歸還時間
...
)
用到的功能有:
1.如果我更改了學生的學號,我希望他的借書記錄仍然與這個學生相關(也就是同時更改借書記錄表的學號);
2.如果該學生已經畢業,我希望刪除他的學號的同時,也刪除它的借書記錄。
等等。
這時候可以用到觸發器。對於1,創建一個Update觸發器:
Create Trigger truStudent
On Student --在Student表中創建觸發器
for Update --為什麼事件觸發
As --事件觸發後所要做的事情
if Update(StudentID)
begin
Update BorrowRecord
Set StudentID=i.StudentID
From BorrowRecord br , Deleted d ,Inserted i --Deleted和Inserted臨時表
Where br.StudentID=d.StudentID
end
理解觸發器裡面的兩個臨時的表:Deleted , Inserted 。注意Deleted 與Inserted分別表示觸發事件的表「舊的一條記錄」和「新的一條記錄」。
一個資料庫系統中有兩個虛擬表用於存儲在表中記錄改動的信息,分別是:
虛擬表Inserted 虛擬表Deleted
在表記錄新增時 存放新增的記錄 不存儲記錄
修改時 存放用來更新的新記錄 存放更新前的記錄
刪除時 不存儲記錄 存放被刪除的記錄 一個Update 的過程可以看作為:生成新的記錄到Inserted表,復制舊的記錄到Deleted表,然後刪除Student記錄並寫入新紀錄。
對於2,創建一個Delete觸發器
Create trigger trdStudent
On Student
for Delete
As
Delete BorrowRecord
From BorrowRecord br , Delted d
Where br.StudentID=d.StudentID
從這兩個例子我們可以看到了觸發器的關鍵:A.2個臨時的表;B.觸發機制。
SQL觸發器實例2
/*
建立虛擬測試環境,包含:表[卷煙庫存表],表[卷煙銷售表]。
請大家注意跟蹤這兩個表的數據,體會觸發器到底執行了什麼業務邏輯,對數據有什麼影響。
為了能更清晰的表述觸發器的作用,表結構存在數據冗餘,且不符合第三範式,這里特此說明。
*/
USE Master
GO
IF EXISTS (SELECT NAME FROM SYSOBJECTS WHERE XTYPE = 』U』 AND NAME = 』卷煙庫存表』)
DROP TABLE 卷煙庫存表
GO
IF EXISTS (SELECT NAME FROM SYSOBJECTS WHERE XTYPE = 』U』 AND NAME = 』卷煙銷售表』)
DROP TABLE 卷煙銷售表
GO
--業務規則:銷售金額 = 銷售數量 * 銷售單價 業務規則。
CREATE TABLE 卷煙銷售表
(
卷煙品牌 VARCHAR(40) PRIMARY KEY NOT NULL,
購貨商 VARCHAR(40) NULL,
銷售數量 INT NULL,
銷售單價 MONEY NULL,
銷售金額 MONEY NULL
)
GO
--業務規則:庫存金額 = 庫存數量 * 庫存單價 業務規則。
CREATE TABLE 卷煙庫存表
(
卷煙品牌 VARCHAR(40) PRIMARY KEY NOT NULL,
庫存數量 INT NULL,
庫存單價 MONEY NULL,
庫存金額 MONEY NULL
)
GO
--創建觸發器,示例1
/*
創建觸發器[T_INSERT_卷煙庫存表],這個觸發器較簡單。
說明: 每當[卷煙庫存表]發生 INSERT 動作,則引發該觸發器。
觸發器功能: 強制執行業務規則,保證插入的數據中,庫存金額 = 庫存數量 * 庫存單價。
注意: [INSERTED]、[DELETED]為系統表,不可創建、修改、刪除,但可以調用。
重要: 這兩個系統表的結構同插入數據的表的結構。
*/
IF EXISTS (SELECT NAME FROM SYSOBJECTS WHERE XTYPE = 』TR』 AND NAME = 』T_INSERT_卷煙庫存表』)
DROP TRIGGER T_INSERT_卷煙庫存表
GO
CREATE TRIGGER T_INSERT_卷煙庫存表
ON 卷煙庫存表
FOR INSERT
AS
--提交事務處理
BEGIN TRANSACTION
--強制執行下列語句,保證業務規則
UPDATE 卷煙庫存表
SET 庫存金額 = 庫存數量 * 庫存單價
WHERE 卷煙品牌 IN (SELECT 卷煙品牌 from INSERTED)
COMMIT TRANSACTION
GO
/*
針對[卷煙庫存表],插入測試數據:
注意,第一條數據(紅塔山新勢力)中的數據符合業務規則,
第二條數據(紅塔山人為峰)中,[庫存金額]空,不符合業務規則,
第三條數據(雲南映像)中,[庫存金額]不等於[庫存數量]乘以[庫存單價],不符合業務規則。
第四條資料庫存數量為0。
請注意在插入數據後,檢查[卷煙庫存表]中的數據是否 庫存金額 = 庫存數量 * 庫存單價。
*/
INSERT INTO 卷煙庫存表(卷煙品牌,庫存數量,庫存單價,庫存金額)
SELECT 』紅塔山新勢力』,100,12,1200 UNION ALL
SELECT 』紅塔山人為峰』,100,22,NULL UNION ALL
SELECT 』雲南映像』,100,60,500 UNION ALL
SELECT 』玉溪』,0,30,0
GO
--查詢數據
SELECT * FROM 卷煙庫存表
GO
/*
結果集
RecordId 卷煙品牌 庫存數量 庫存單價 庫存金額
-------- ------------ -------- ------- ---------
1 紅塔山新勢力 100 12.0000 1200.0000
2 紅塔山人為峰 100 22.0000 2200.0000
3 雲南映像 100 60.0000 6000.0000
4 玉溪 0 30.0000 .0000
(所影響的行數為 4 行)
*/
--觸發器示例2
/*
創建觸發器[T_INSERT_卷煙銷售表],該觸發器較復雜。
說明: 每當[卷煙庫存表]發生 INSERT 動作,則引發該觸發器。
觸發器功能: 實現業務規則。
業務規則: 如果銷售的卷煙品牌不存在庫存或者庫存為零,則返回錯誤。
否則則自動減少[卷煙庫存表]中對應品牌卷煙的庫存數量和庫存金額。
*/
IF EXISTS (SELECT NAME FROM SYSOBJECTS WHERE XTYPE = 』TR』 AND NAME = 』T_INSERT_卷煙銷售表』)
DROP TRIGGER T_INSERT_卷煙銷售表
GO
CREATE TRIGGER T_INSERT_卷煙銷售表
ON 卷煙銷售表
FOR INSERT
AS
BEGIN TRANSACTION
--檢查數據的合法性:銷售的卷煙是否有庫存,或者庫存是否大於零
IF NOT EXISTS (
SELECT 庫存數量
FROM 卷煙庫存表
WHERE 卷煙品牌 IN (SELECT 卷煙品牌 FROM INSERTED)
)
BEGIN
--返回錯誤提示
RAISERROR(』錯誤!該卷煙不存在庫存,不能銷售。』,16,1)
--回滾事務
ROLLBACK
RETURN
END
IF EXISTS (
SELECT 庫存數量
FROM 卷煙庫存表
WHERE 卷煙品牌 IN (SELECT 卷煙品牌 FROM INSERTED) AND
庫存數量 <= 0
)
BEGIN
--返回錯誤提示
RAISERROR(』錯誤!該卷煙庫存小於等於0,不能銷售。』,16,1)
--回滾事務
ROLLBACK
RETURN
END
--對合法的數據進行處理
--強制執行下列語句,保證業務規則
UPDATE 卷煙銷售表
SET 銷售金額 = 銷售數量 * 銷售單價
WHERE 卷煙品牌 IN (SELECT 卷煙品牌 FROM INSERTED)
DECLARE @卷煙品牌 VARCHAR(40)
SET @卷煙品牌 = (SELECT 卷煙品牌 FROM INSERTED)
DECLARE @銷售數量 MONEY
SET @銷售數量 = (SELECT 銷售數量 FROM INSERTED)
UPDATE 卷煙庫存表
SET 庫存數量 = 庫存數量 - @銷售數量,
庫存金額 = (庫存數量 - @銷售數量)*庫存單價
WHERE 卷煙品牌 = @卷煙品牌
COMMIT TRANSACTION
GO
--請大家自行跟蹤[卷煙庫存表]和[卷煙銷售表]的數據變化。
--針對[卷煙銷售表],插入第一條測試數據,該數據是正常的。
INSERT INTO 卷煙銷售表(卷煙品牌,購貨商,銷售數量,銷售單價,銷售金額)
SELECT 』紅塔山新勢力』,』某購貨商』,10,12,1200
GO
--針對[卷煙銷售表],插入第二條測試數據,該數據 銷售金額 不等於 銷售單價 * 銷售數量。
--觸發器將自動更正數據,使 銷售金額 等於 銷售單價 * 銷售數量。
INSERT INTO 卷煙銷售表(卷煙品牌,購貨商,銷售數量,銷售單價,銷售金額)
SELECT 』紅塔山人為峰』,』某購貨商』,10,22,2000
GO
--針對[卷煙銷售表],插入第三條測試數據,該數據中的卷煙品牌在 卷煙庫存表中找不到對應。
--觸發器將報錯。
INSERT INTO 卷煙銷售表(卷煙品牌,購貨商,銷售數量,銷售單價,銷售金額)
SELECT 』紅河V8』,』某購貨商』,10,60,600
GO
/*
結果集
伺服器: 消息 50000,級別 16,狀態 1,過程 T_INSERT_卷煙銷售表,行 15
錯誤!該卷煙不存在庫存,不能銷售。
*/
--針對[卷煙銷售表],插入第三條測試數據,該數據中的卷煙品牌在 卷煙庫存表中庫存為0。
--觸發器將報錯。
INSERT INTO 卷煙銷售表(卷煙品牌,購貨商,銷售數量,銷售單價,銷售金額)
SELECT 』玉溪』,』某購貨商』,10,30,300
GO
/*
結果集
伺服器: 消息 50000,級別 16,狀態 1,過程 T_INSERT_卷煙銷售表,行 29
錯誤!該卷煙庫存小於等於0,不能銷售。
*/
--查詢數據
SELECT * FROM 卷煙庫存表
SELECT * FROM 卷煙銷售表
GO
/*
補充:
1、本示例主要通過一個簡單的業務規則實現來進行觸發器使用的說明,具體的要根據需要靈活處理;
2、關於觸發器要理解並運用好 INSERTED ,DELETED 兩個系統表;
3、本示例創建的觸發器都是 FOR INSERT ,具體的語法可參考:
Trigger語法
CREATE TRIGGER trigger_name
ON { table | view }
[ WITH ENCRYPTION ] --用於加密觸發器
{
{ { FOR | AFTER | INSTEAD OF } { [ INSERT ] [ , ] [ UPDATE ] }
[ WITH APPEND ]
[ NOT FOR REPLICATION ]
AS
[ { IF UPDATE ( column )
[ { AND | OR } UPDATE ( column ) ]
[ ...n ]
| IF ( COLUMNS_UPDATED ( ) { bitwise_operator } updated_bitmask )
{ comparison_operator } column_bitmask [ ...n ]
} ]
sql_statement [ ...n ]
}
}
4、關於觸發器,還應該注意
(1)、DELETE 觸發器不能捕獲 TRUNCATE TABLE 語句。
(2)、觸發器中不允許以下 Transact-SQL 語句:
ALTER DATABASE CREATE DATABASE DISK INIT
DISK RESIZE DROP DATABASE LOAD DATABASE
LOAD LOG RECONFIGURE RESTORE DATABASE
RESTORE LOG
(3)、觸發器最多可以嵌套 32 層。
*/
--修改觸發器
--實質上,是將 CREATE TRIGGER ... 修改為 ALTER TRIGGER ...即可。
--刪除觸發器
DROP TRIGGER xxx
GO
--刪除測試環境
DROP TABLE 卷煙庫存表
GO
DROP TABLE 卷煙銷售表
GO
DROP TRIGGER T_INSERT_卷煙庫存表
GO
DROP TRIGGER T_INSERT_卷煙銷售表
GO
##################################################################
觸發器的基礎知識和例子
:create trigger tr_name
on table/view
{for | after | instead of } [update][,][insert][,][delete]
[with encryption]
as {batch | if update (col_name) [{and|or} update (col_name)] }
說明:
1 tr_name :觸發器名稱
2 on table/view :觸發器所作用的表。一個觸發器只能作用於一個表
3 for 和after :同義
4 after 與instead of :sql 2000新增項目afrer 與 instead of 的區別
After
在觸發事件發生以後才被激活,只可以建立在表上
Instead of
代替了相應的觸發事件而被執行,既可以建立在表上也可以建立在視圖上
5 insert、update、delete:激活觸發器的三種操作,可以同時執行,也可選其一
6 if update (col_name):表明所作的操作對指定列是否有影響,有影響,則激活觸發器。此外,因為delete 操作只對行有影響,
所以如果使用delete操作就不能用這條語句了(雖然使用也不出錯,但是不能激活觸發器,沒意義)。
7 觸發器執行時用到的兩個特殊表:deleted ,inserted
deleted 和inserted 可以說是一種特殊的臨時表,是在進行激活觸發器時由系統自動生成的,其結構與觸發器作用的表結構是一
樣的,只是存放 的數據有差異。
續
下面表格說明deleted 與inserted 數據的差異
deleted 與inserted 數據的差異
Inserted
存放進行insert和update 操作後的數據
Deleted
存放進行delete 和update操作前的數據
注意:update 操作相當於先進行delete 再進行insert ,所以在進行update操作時,修改前的數據拷貝一條到deleted 表中,修改後
的數據在存到觸發器作用的表的同時,也同時生成一條拷貝到insered表中
C. 急! DML觸發器中,根據引發觸發器自行執行的操作不同,可以分為那三類根據激活的時機又可分為那三類
按操作分: Insert 觸發器、Update 觸發器、Delete 觸發器;
按時間分: Before 觸發器、Instead of 觸發器、 After 觸發器。
D. 請問在sqlserver中什麼是前觸發型觸發器,什麼是後觸發型觸發器,怎麼區分呢
前觸發器:指在執行INSERT,UPDATE,DELETE之前去觸發【觸發器】要執行的語句
後觸發器:指在執行INSERT,UPDATE,DELETE之後再去觸發【觸發器】要執行的語句。
比如一個update觸發器,要執行刪除操作。
那麼有兩種情況,第一先update在delete(後觸發器)
第二先delete在update(前觸發器)
E. 觸發器的應用和用法
1、觸發器的定義就是說某個條件成立的時候,觸發器裡面所定義的語句就會被自動的執行。因此觸發器不需要人為的去調用,也不能調用。
2、觸發器的觸發條件其實在定義的時候就已經設定好了。
3、觸發器可以分為語句級觸發器和行級觸發器。簡單的說就是語句級的觸發器可以在某些語句執行前或執行後被觸發。而行級觸發器則是在定義的了觸發的表中的行數據改變時就會被觸發一次。
4、具體舉例:
1)、 在一個表中定義語句級的觸發器,當這個表被刪除時,程序就會自動執行觸發器裡面定義的操作過程。這個【刪除表的操作】就是觸發器執行的條件。
2)、 在一個表中定義行級的觸發器,那當【這個表中一行數據發生變化】的時候,比如刪除了一行記錄,那觸發器也會被自動執行了。
5、創建觸發器語句
6、觸發器作用(應用場景)
(1)數據確認
(2)實施復雜的安全性檢查
(3)做日誌記錄,跟蹤表上所做的數據操作等
(4)數據的備份和同步;
(5)執行什麼時間可以激活觸發器擴展閱讀
一、觸發器介紹
1、資料庫觸發器是一個與表相關聯的、存儲的 PL/SQL 程序。每當一個特定的數據操作語句(Insert,update,delete)在指定的表上發出時,Oracle 自動地執行觸發器中定義的語句序
列。
2、觸發器的作用
觸發器可用於:
(1)數據確認
(2)實施復雜的安全性檢查
(3)做審計,跟蹤表上所做的數據操作等
(4)數據的備份和同步
3、觸發器的類型
(1)語句級觸發器
在指定的操作語句操作之前或之後執行一次,不管這條語句影響了多少行 。
(2)行級觸發器(FOR EACH ROW)
觸發語句作用的每一條記錄都被觸發。在行級觸發器中使用 old 和 new 偽記錄變數,識別值的狀態。
4、創建觸發器的語法
CREATE [or REPLACE] TRIGGER 觸發器名
{BEFORE |AFTER}
{DELETE | INSERT | UPDATE [OF 列名]}
ON 表名
[FOR EACH ROW [WHEN(條件) ] ]
參考資料
網路-Oracle觸發器
F. 觸發器什麼時候使用有什麼功能舉個簡單的例子說明一下。
觸發器(trigger)是個特殊的存儲過程,它的執行不是由程序調用,也不是手工啟動,而是由事件來觸發,比如當對一個表進行操作( insert,delete, update)時就會激活它執行。觸發器經常用於加強數據的完整性約束和業務規則等。 觸發器可以從 DBA_TRIGGERS ,USER_TRIGGERS 數據字典中查到。 資料庫領域名詞觸發器可以查詢其他表,而且可以包含復雜的 SQL 語句。它們主要用於強制服從復雜的業務規則或要求。例如:您可以根據客戶當前的帳戶狀態,控制是否允許插入新訂單。
觸發器也可用於強制引用完整性,以便在多個表中添加、更新或刪除行時,保留在這些表之間所定義的關系。然而,強制引用完整性的最好方法是在相關表中定義主鍵和外鍵約束。如果使用資料庫關系圖,則可以在表之間創建關系以自動創建外鍵約束。
創建觸發器的SQL語法
DELIMITER |
CREATE TRIGGER `<databaseName>`.`<triggerName>`
< [ BEFORE | AFTER ] > < [ INSERT | UPDATE | DELETE ] >
ON <tableName>
FOR EACH ROW
BEGIN
--do something
END |
觸發器的優點
觸發器可通過資料庫中的相關表實現級聯更改;不過,通過級聯引用完整性約束可以更有效地執行這些更改。觸發器可以強制比用 CHECK 約束定義的約束更為復雜的約束。與 CHECK 約束不同,觸發器可以引用其它表中的列。例如,觸發器可以使用另一個表中的 SELECT 比較插入或更新的數據,以及執行其它操作,如修改數據或顯示用戶定義錯誤信息。觸發器也可以評估數據修改前後的表狀態,並根據其差異採取對策。一個表中的多個同類觸發器(INSERT、UPDATE 或 DELETE)允許採取多個不同的對策以響應同一個修改語句。
比較觸發器與約束
約束和觸發器在特殊情況下各有優勢。觸發器的主要好處在於它們可以包含使用 Transact-SQL 代碼的復雜處理邏輯。因此,觸發器可以支持約束的所有功能;但它在所給出的功能上並不總是最好的方法。實體完整性總應在最低級別上通過索引進行強制,這些索引或是 PRIMARY KEY 和 UNIQUE 約束的一部分,或是在約束之外獨立創建的。假設功能可以滿足應用程序的功能需求,域完整性應通過 CHECK 約束進行強制,而引用完整性 (RI) 則應通過 FOREIGN KEY 約束進行強制。在約束所支持的功能無法滿足應用程序的功能要求時,觸發器就極為有用。
例如:除非 REFERENCES 子句定義了級聯引用操作,否則 FOREIGN KEY 約束只能以與另一列中的值完全匹配的值來驗證列值。
CHECK 約束只能根據邏輯表達式或同一表中的另一列來驗證列值。如果應用程序要求根據另一個表中的列驗證列值,則必須使用觸發器。
約束只能通過標準的系統錯誤信息傳遞錯誤信息。如果應用程序要求使用(或能從中獲益)自定義信息和較為復雜的錯誤處理,則必須使用觸發器。
觸發器可通過資料庫中的相關表實現級聯更改;不過,通過級聯引用完整性約束可以更有效地執行這些更改。
觸發器可以禁止或回滾違反引用完整性的更改,從而取消所嘗試的數據修改。當更改外鍵且新值與主鍵不匹配時,此類觸發器就可能發生作用。例如,可以在 titleauthor.title_id 上創建一個插入觸發器,使它在新值與 titles.title_id 中的某個值不匹配時回滾一個插入。不過,通常使用 FOREIGN KEY 來達到這個目的。
如果觸發器表上存在約束,則在 INSTEAD OF 觸發器執行後但在 AFTER 觸發器執行前檢查這些約束。如果約束破壞,則回滾 INSTEAD OF 觸發器操作並且不執行 AFTER 觸發器。
觸發器到底可不可以在視圖上創建 在 SQL Server�6�4 聯機叢書中,是沒有說觸發器不能在視圖上創建的, 並且在語法解釋中表明:
在 CREATE TRIGGER 的 ON 之後可以是視圖。 然而,事實似乎並不是如此,很多專家也說觸發器不能在視圖上創建。我也專門作了測試,的確如此,不管是普通視圖還是索引視圖,都無法在上面創建觸發器,真的是這樣嗎?請點擊詳細,但是無可厚非的是:當在臨時表或系統表上創建觸發器時會遭到拒絕。 深刻理解 FOR CREATE TRIGGER 語句的 FOR 關鍵字之後可以跟 INSERT、UPDATE、DELETE 中的一個或多個,也就是說在其它情況下是不會觸發觸發器的, 包括 SELECT、TRUNCATE、WRITETEXT、UPDATETEXT。相關內容 一個有趣的應用我們看到許多注冊系統在注冊後都不能更改用戶名,但這多半是由應用程序決定的, 如果直接打開資料庫表進行更改,同樣可以更改其用戶名, 在觸發器中利用回滾就可以巧妙地實現無法更改用戶名……詳細內容 觸發器內部語句出錯時…… 這種情況下,前面對數據更改操作將會無效。舉個例子,在表中插入數據時觸發觸發器,而觸發器內部此時發生了運行時錯誤,那麼將返回一個錯誤值,並且拒絕剛才的數據插入。不能在觸發器中使用的語句 觸發器中可以使用大多數 T-SQL 語句,但如下一些語句是不能在觸發器中使用的。
CREATE 語句,如:CREATE DATABASE、CREATE TABLE、CREATE INDEX 等。
ALTER 語句,如:ALTER DATABASE、ALTER TABLE、ALTER INDEX 等。
DROP 語句,如:DROP DATABASE、DROP TABLE、DROP INDEX 等。
DISK 語句,如:DISK INIT、DISK RESIZE。
LOAD 語句,如:LOAD DATABASE、LOAD LOG。
RESTORE 語句,如:RESTORE DATABASE、RESTORE LOG。
RECONFIGURE
TRUNCATE TABLE 語句在sybase的觸發器中不可使用!
慎用觸發器 觸發器功能強大,輕松可靠地實現許多復雜的功能,為什麼又要慎用呢。觸發器本身沒有過錯,但由於我們的濫用會造成資料庫及應用程序的維護困難。在資料庫操作中,我們可以通過關系、觸發器、存儲過程、應用程序等來實現數據操作…… 同時規則、約束、預設值也是保證數據完整性的重要保障。如果我們對觸發器過分的依賴,勢必影響資料庫的結構,同時增加了維護的復雜程序. [編輯本段]數字電路領域名詞學名「雙穩態多諧振盪器(Bistable Multivibrator)」。觸發器(Flip Flop)是一種可以存儲電路狀態的電子元件。最簡單的是由兩個或非門,兩個輸入端和兩個輸出端組成的RS觸發器(見圖)。復雜一些的有帶時鍾(CLK)段和D(Data)端,在CLK端為高電平時跟隨D端狀態,而在CLK端變為低電平的瞬間鎖存信號的D觸發器。更常用的是兩個簡單D觸發器級聯而成的在時鍾下跳沿鎖存信號的邊緣D觸發器,廣泛應用於計數器、運算器、存儲器等電子部件。
觸發器的電路結構和邏輯功能:
邏輯功能,是指觸發器的次態和現態及輸入信號之間在穩態下的邏輯關系。這種邏輯關系可以用特性表、特性方程或狀態轉換圖給出。
根據邏輯功能的不同特點,把觸發器分為RS、JK、T、D等幾種類型。
電路結構,是指電路中門電路的種類及組合方式。
基本RS觸發器、同步RS觸發器、主從觸發器、邊緣觸發器等是指電路結構的不同形式。由於電路結構形式的不同,帶來了各不相同的動作特點。
同一種邏輯功能的觸發器可以用不同的電路結構實現。反過來說,用同一種電路結構形式可以作成不同邏輯功能的觸發器。
觸發器的類型:
按邏輯功能不同分為:RS觸發器、D觸發器、JK觸發器、T觸發器。
按觸發方式不同分為:電平觸發器、邊沿觸發器和主從觸發器。
按電路結構不同分為:基本RS觸發器和鍾控觸發器。
按存儲數據原理不同分為:靜態觸發器和動態觸發器。
按構成觸發器的基本器件不同分為:雙極型觸發器和MOS型觸發器。
照明配件
用於高強度氣體放電燈(H.I.D)的啟動,型號繁多.由於高強度氣體放電燈啟動時需要一個高電壓來使氣體電離進入等離子態,因而需要一個高壓發生器做為啟動器。這就是觸發器早期的機械型觸發器已經淘汰。現在絕大多數觸發器都是使用可控硅或高壓觸發二極體的電子觸發器,常用的型號有:OSRAM 的 CD-7 飛利浦的 SI51 SN58 愛倫的ALK400等
G. 觸發器什麼時候使用有什麼功能
1.如果我更改了學生的學號,我希望他的借書記錄仍然與這個學生相關(也就是同時更改借書記錄表的學號);
2.如果該學生已經畢業,我希望刪除他的學號的同時,也刪除它的借書記錄。這時候可以用到觸發器。
H. 對表執行什麼操作會激活觸發器
對表進行Insert、Delete、Update操作的時候。
它的執行不能由程序調用,也不能手動啟用,而只能是通過事件來觸發,比如當對表進行Insert、Delete、Update操作的時候,就會激活觸發器來執行,所以觸發器通常用於保證數據完整性和一些業務約束規則等。
I. sqlserver 中創建觸發器execute master有什麼作用
after等價於for,是事後觸發。instead of則會取代原來的操作,例如在你的例子里,將不再執行插入操作,而是執行觸發器里的操作。
execute as是用來定義模塊的執行上下文
EXECUTE AS { CALLER | SELF | OWNER | 'user_name' }
其中CALLER指模塊調用方,SELF指創建或更改模塊的用戶,OWNER指模塊的當前所有者, 『user_name』 則是指定的用戶。