㈠ sql實驗:觸發器
-------1、
CREATE TRIGGER tr_insert
ON 學生表
FOR INSERT
AS
DECLARE @Class_ID int,
@Stu_id int
select top 1 @Class_ID=課號 from (select 課號,count(*) as total from 選課表 group by 課號) t1 order by t1.total desc
select @Stu_id=學號 from inserted
insert into 選課表 values(@Stu_id, @Class_ID, 0)
GO
--------2、
CREATE TRIGGER tr_delete
ON 學生表
FOR DELETE
AS
DECLARE @Stu_id int
select @Stu_id=學號 from deleted
if exists (select 1 from 選課表 where 學號=@Stu_id)
begin
RAISERROR ('拒絕刪除學號為%d的記錄,因該生有選課記錄',@Stu_id)
ROLLBACK TRANSACTION
end
/*要求在刪除學生信息同時,將相關表中的信息全部刪除(因不知道你的表,你自己添加根據@Stu_id(學號)來在下面添加額外對應表的刪除吧*/
GO
㈡ 怎麼用SQL做觸發器
我寫的,沒有經過測試,僅供參考,如果不對的話請原諒
CREATE TRIGGER books_rt_upd
ON books_rt
FOR UPDATE
AS
IF UPDATE (return_date)
BEGIN
-- 定義 借書日期
declare @lend_date date
-- 定義 應還書日期
declare @return_date date
-- 定義 超出天數
declare @exday int
-- 定義 超出價格
declare @exfee decimal
-- 定義 用戶id
declare @userid
-- 定義 用戶id
declare @usertype
-- 修改用戶歸還日期,和借書的id號
select @return_date=return_date , @lendid = lendid from INSERTED
select
@lend_date=lend_date,@userid=userid ,@usertype=@usertype
from
books_rt
where lendid in (select lendid from INSERTED)
-- 計算超出多少天並乘以價格
set @exday = @return_date - @lend_date
-- 根據用戶級別察看是否超過天數
IF @usertype= '01' begin
if @exday > '10' --01級別可以借書10天
begin
set @exday = @exday - 10
end
end
IF @usertype= '02' begin
if @exday > '20' --02級別可以借書20天
begin
set @exday = @exday - 20
end
end
set @exfee = @exday * 0.3
-- 修改用戶帳戶表
update user_account set user_fee = userfee - @exfee
where userid = @userid
END
㈢ 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定時觸發器
這個不能用觸發器,要用作業。
打開企業管理器,進入你伺服器名下的「管理」,啟動SQL Server代理。然後查看伺服器屬性,選中「自動啟動SQL Server代理」。
接下來進入SQL Server代理下的「作業」,在右邊點右鍵選「新建作業」。
在「常規」里,隨便輸入一個作業名,分類要選最後一項「資料庫維護」。
在「步驟」里,點「新建步驟」,隨便輸入一個步驟名,資料庫選成你的資料庫,命令里輸入你刪除記錄的語句,也可以通過「打開」來裝載T-SQL腳本,弄好後記得分析一下,沒有問題再繼續。在「高級」里將「失敗時的操作」改成「轉到下一步」。
在「調度」里,點「新建調度」,隨便輸入一個調度名,點「更改」,「發生頻率」選每天,「一次發生於」里設置17:00:00,然後點「確定」,再點「確定」,再點「確定」,配置就完成了。
㈤ SQl中觸發器怎樣執行的
創建觸發器 是特殊的存儲過程,自動執行,一般不要有返回值。
1、後觸發器 (AFTER,FOR)先執行對應語句,後執行觸發器中的語句。
2、前觸發器 並沒有真正的執行觸發語句(insert,update,delete),而是執行觸發後的語句。
3、行級觸發器 (FOR EACH ROW) 在SQL server 中不存在。
(5)sql觸發器教程完整版擴展閱讀:
創建觸發的語法
CREATE TRIGGER trigger_name --觸發器名稱
ON table_name --觸發的表
[WITH ENCRYPTION]
FOR [DELETE, INSERT, UPDATE] --選擇觸發器類型
AS --觸發後要做的語句
T-SQL語句
GO --結束標記