sql建立觸發器
c語言怎麼使用sql觸發器:
定義: 何為觸發器?在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觸發器怎麼做
二樓的說的對,insert
into...select
語句是復製表a的數據到表b里,而且表2不能自定義,是由語句創建的,如果表b已經存在則會出錯.
如果樓主要執行insert
into...select,首先要判斷插入的表是否已經存在,如果存在要將其刪除後在執行.
樓主如果你只是想把剛插入的數據的那3列在插入到另一個表裡,完全沒必要那樣做,直接從inserted表(這個表只在insert觸發器適用)里讀就能讀的到剛插入的內容了,讀取出來後在用insert
語句插入到另一個表即可.
㈢ SQL里中存儲過程和觸發器,如何創建
觸發器是一種特殊的存儲過程,
2.觸發器是在對表進行插入、更新或刪除操作時自動執行的存儲過程
3.觸發器通常用於強制業務規則
4.觸發器是一種高級約束,可以定義比用CHECK 約束更為復雜的約束
5.可執行復雜的SQL語句(if/while/case)DELETE 觸發器
INSERT 觸發器
UPDATE 觸發器/*----------Insert 插入 觸發器------------*/
Create Trigger Tri_insert
on students /*針對某個表,觸發器是建立在表關繫上的*/
for insert /*採用的是哪種觸發器*/
as
declare @stu_id int;
declare @stu_score varchar(200);
select @stu_id=s_id from inserted /*這里的Inserted 是在創建觸發器時候 系統自動創建的內存表*/
insert into student_Score(s_id,ss_score)values(@stu_id,'100')go
--就是插一條數據進入students中,Tri_insert觸發器就會自動在student_Score插入相關的學生的一條分數的數據
insert into students(s_name,s_classId) values('黃馳',6)select * from student_Score
㈣ sql server2012如何建立觸發器
首先你當然要有一個資料庫了,這里我使用自己創建的資料庫booksDB。
在資料庫booksDB上創建觸發器,右擊觸發器->新建觸發器,打開之後的界面如下所示
6
資料庫的增刪改查類似
㈤ SQL中,觸發器是什麼
1. 基本概念x0dx0a觸發器是特殊的存儲過程,基於一個表創建,主要作用就是實現由主鍵和外鍵所不能保證的復雜的參照完整性和數據一致性。x0dx0a當觸發器所保護的數據發生變化(update,insert,delete)後,自動運行以保證數據的完整性和正確性。通俗的說:通過一個動作(update,insert,delete)調用一個存儲過程(觸發器)。x0dx0a2. 類型x0dx0a(1)DML觸發器x0dx0a在資料庫中發生數據操作語言(DML)事件時將啟用。DML 事件包括在指定表或視圖中修改數據的 INSERT 語句、UPDATE 語句或 DELETE 語句。DML 觸發器可以查詢其他表,還可以包含復雜的 T-SQL 語句。系統將觸發器和觸發它的語句作為可在觸發器內回滾的單個事務對待,如果檢測到錯誤(例如,磁碟空間不足),則整個事務即自動回滾。x0dx0a(2)DDL 觸發器x0dx0aSQL Server 2005 的新增功能。當伺服器或資料庫中發生數據定義語言(DDL)事件時將調用這些觸發器。但與DML觸發器不同的是,它們不會為響應針對表或視圖的UPDATE、INSERT或DELETE語句而激發,相反,它們會為響應多種數據定義語言(DDL)語句而激發。這些語句主要是以CREATE、ALTER和DROP開頭的語句。DDL觸發器可用於管理任務,例如審核和控制資料庫操作。x0dx0a 創建DML觸發器x0dx0a1. 使用存儲過程模板創建存儲過程x0dx0a在【對象資源管理器】窗口中,展開「資料庫」節點,再展開所選擇的具體資料庫節點,再展開「表」節點,右擊要創建觸發器的「表」,選擇「新建觸發器」命令,如圖所示:x0dx0a在右側查詢編輯器中出現觸發器設計模板,用戶可以在此基礎上編輯觸發器,單擊「執行」按鈕,即可創建該觸發器。x0dx0ax0dx0a2. 使用T-SQL語句創建表x0dx0aCREATE TRIGGER 觸發器x0dx0aON 表名x0dx0aFOR[update,insert,delete ]x0dx0aAS SQL語句x0dx0a例9-6:創建基於表reader ,DELETE操作的觸發器。x0dx0aUSE Libraryx0dx0aGOx0dx0aIF EXISTS(SELECT name FROM sysobjectsx0dx0a WHERE name='reader_d' AND type='TR')x0dx0aDROP TRIGGER reader_d --如果已經存在觸發器reader_d則刪除x0dx0aGOx0dx0aCREATE TRIGGER reader_d --創建觸發器x0dx0aON reader --基於表 x0dx0aFOR DELETE --刪除事件x0dx0aASx0dx0aPRINT '數據被刪除!' --執行顯示輸出x0dx0aGOx0dx0a 試試吧!x0dx0a應用:x0dx0aUSE Libraryx0dx0aGOx0dx0aDELETE readerx0dx0awhere Rname='aaa'x0dx0a執行結果:x0dx0a數據被刪除!x0dx0a(所影響的行數為 1 行)x0dx0a例9-7:在表borrow中添加借閱信息記錄時,得到該書的應還日期。x0dx0a說明:在表borrow中增加一個應還日期SReturnDate。x0dx0aUSE Libraryx0dx0aIF EXISTS (SELECT name FROM sysobjectsx0dx0aWHERE name ='T_return_date' AND type='TR')x0dx0aDROP TRIGGER T_return_datex0dx0aGOx0dx0aCREATE TRIGGER T_return_date --創建觸發器x0dx0aON Borrow --基於表borrowx0dx0aAfter INSERT --插入操作x0dx0aASx0dx0a--查詢插入記錄INSERTED中讀者的類型x0dx0aDECLARE @type int,@dzbh char(10),@tsbh char(15)x0dx0aSET @dzbh=(SELECT RID FROM inserted)x0dx0aSET @tsbh=(SELECT BID FROM inserted)x0dx0aSELECT @type= TypeIDx0dx0aFROM readerx0dx0aWHERE RID=(SELECT RID FROM inserted)--副本x0dx0a/*把Borrow表中的應還日期改為x0dx0a當前日期加上各類讀者的借閱期限*/x0dx0aUPDATE Borrow SET SReturnDate=getdate()+x0dx0aCASE x0dx0a WHEN @type=1 THEN 90x0dx0a WHEN @type=2 THEN 60x0dx0a WHEN @type=3 THEN 30x0dx0aENDx0dx0aWHERE RID=@dzbh and BID=@tsbhx0dx0a應用:x0dx0aUSE Libraryx0dx0aINSERT INTO borrow(RID,BID) values(','TP85-08')x0dx0a查看記錄:x0dx0a x0dx0a例9-8:在資料庫Library中,當讀者還書時,實際上要修改表brorrowinf中相應記錄還期列的值,請計算出是否過期。x0dx0aUSE Libraryx0dx0aIF EXISTS(SELECT name FROM sysobjectsx0dx0aWHERE name='T_fine_js' AND type='TR')x0dx0aDROP TRIGGER T_fine_jsx0dx0aGOx0dx0aCREATE TRIGGER T_fine_jsx0dx0aON borrowx0dx0aAfter UPDATEx0dx0aASx0dx0aDECLARE @days int,@dzbh char(10),@tsbh char(15)x0dx0aSET @dzbh=(select RID from inserted)x0dx0aSET @tsbh=(select BID from inserted)x0dx0aSELECT @days=DATEDIFF(day, ReturnDate, SReturnDate)x0dx0a--DATEDIFF函數返回兩個日期之差,單位為DAYx0dx0aFROM borrowx0dx0aWHERE RID=@dzbh and BID=@tsbhx0dx0aIF @days>0x0dx0a PRINT '沒有過期!'x0dx0aELSEx0dx0a PRINT '過期'+convert(char(6),@days)+'天'x0dx0aGOx0dx0a應用:x0dx0aUSE Libraryx0dx0aUPDATE borrow SET ReturnDate=-12-12'x0dx0aWHERE RID=' and BID='TP85-08'x0dx0aGOx0dx0a執行結果:x0dx0a過期-157 天x0dx0a(1 行受影響)x0dx0a例9-9:對Library庫中Reader表的 DELETE操作定義觸發器。x0dx0aUSE Libraryx0dx0aGOx0dx0aIF EXISTS(SELECT name FROM sysobjectsx0dx0a WHERE name='reader_d' AND type='TR')x0dx0aDROP TRIGGER reader_dx0dx0aGOx0dx0aCREATE TRIGGER reader_dx0dx0aON Readerx0dx0aFOR DELETEx0dx0aASx0dx0aDECLARE @data_yj intx0dx0aSELECT @data_yj=Lendnumx0dx0aFROM deletedx0dx0aIF @data_yj>0x0dx0a BEGINx0dx0a PRINT '該讀者不能刪除!還有'+convert(char(2),@data_yj)+'本書沒還。x0dx0a ROLLBACKx0dx0a ENDx0dx0aELSEx0dx0a PRINT '該讀者已被刪除!'x0dx0aGOx0dx0a應用:x0dx0aUSE Libraryx0dx0aGOx0dx0aDELETE Reader WHERE RID='x0dx0a執行結果:x0dx0a該讀者不能刪除!還有4 本書沒還。x0dx0a 修改觸發器x0dx0aALTER TRIGGER 觸發器x0dx0a 刪除觸發器x0dx0aDROP TRIGGER 觸發器x0dx0a 查看觸發器x0dx0asp_helptext trigger_namex0dx0asp_helptrigger table_name
㈥ sql建立觸發器
(1)
_t
declarev_EIWeightfloat;
begin
selectsum(EIWeight)+:new.EIWeightintov_EIWeight
fromEvalIndexwhereEIID=:new.EIID;
ifv_EIWeight>1then
RAISE_APPLICATION_ERROR(-20001,'總權重超過1');
else
DBMS_OUTPUT.put_line('總權重為:'||v_EIWeight);
endif;
end;
(2)
_t
begin
=:new.EResEvalued;
end;
(3)
_vinsteadof
insertonevalStu_vforeachrow
insertintoStudent(sname,sphone)
values(:new.sname,:new.sphone);
end;
㈦ Sql 2000資料庫怎麼創建觸發器,有誰會,截個圖顯示出來看一下
1.使用T-SQL語句創建觸發器
創建觸發器使用CREATE TRIGGER語句。 語法格式如下:
CREATE TRIGGER 觸發器名ON 表名 [WITH ENCRYPTION]
FOR {[DELETE][,][INSERT][,][UPDATE] } [NOT FOR REPLICATION] AS
SQL語句
[RETURE 整數表達式]
觸發器作為一種資料庫對象,在syscomment 表中存儲有完整的文本定義信息。可以使用WITH ENCRYPTION 對訪問syscomment表的入口進行加密。
NOT FOR REPLICATION: 定義在復制過程中,不執行觸發器操作。 【例1】創建一個針對LWQK 表的觸發器,列印共修改了多少行數據。
use lwzz
if exists (select name from sysobjects where name='tr_lwqk_update' and type='tr') drop trigger tr_lwqk_update go
use lwzz go
create trigger tr_lwqk_update on lwqk for update as
declare @msg varchar(100)
select @msg=str(@@rowcount)+'lwzz updated by this statement' print @msg return
go
在CREATE TRIGGER語句中不能使用SELECT語句返回對表格查詢的數據,因為觸發器不接受用戶應用程序傳遞的參數,從而也無法向用戶應用程序返回查詢表格數據所得到的結果。 在創建觸發器的語句中,禁止使用下列T-SQL語句: ALTER DATABASE ALTER PROCEDURE ALTER TABLE ALTER TRIGGER ALTER VIEW CREATE DATABASE CREATE DEFAULT CREATE INDEX CREATE PROCEDURE CREATE RULE CREATE TABLE CREATE TRIGGER DROP DATABASE DROP DEFAULT DROP INDEX DROP PROCEDURE DROP RULE DROP TABLE DROP TRIGGER DROP VIEW
GRANT RESTORE DATABASE RESTORE LOG REVOKE
TRUNCATE TABLE
由於系統表所存儲數據的特殊性和重要性,所以建議用戶不要自己在系統表上建立觸發器。 在創建觸發器時,不允許RETURN返回體現運行狀態的數據。
【例2】創建一個當LWQK表執行INSERT、UPDATE操作時觸發的觸發器。
create trigger tr_procts_insupd
on lwqk
for insert,update as
……
由於SQL Sever 支持在同一個表的同一種操作類型上建立多個觸發器,所以當建了tr_procts_insupd觸發器後,在LWQK表執行INSERT操作時將觸發tr_procts_insupd觸發器,在執行UPDATE操作時將觸發tr_proct_update和tr_procts_insupd觸發器,他們都是有效的觸發器。
㈧ SQL里中存儲過程和觸發器,如何創建
存儲過程可以直接用sql語句創建,觸發器可以在表修改中創建
Create
Procere
name
As
㈨ SQL觸發器怎麼做
CREATE
TRIGGER
[km]
ON
員工表
AFTER
DELETE
AS
BEGIN
DELETE
FROM
工資表
WHERE
員工編號
IN
(SELECT
員工編號
FROM
deleted)
END
CREATE
TRIGGER
[gf]
ON
員工表
AFTER
UPDATE
AS
BEGIN
UPDATE
工資表
SET
部門編號=(SELECT
部門編號
FROM
inserted)
WHERE
員工編號=(SELECT
員工編號
FROM
inserted)
END
㈩ SQl中怎麼樣創建觸發器
創建觸發器:
Create
Trigger
名稱
On
表名
For
類型
As
Sql語句
希望對你有幫助!