国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 數(shù)據(jù)庫(kù) > SQL Server > 正文

SQLSever中的觸發(fā)器基本語(yǔ)法與作用

2024-08-31 01:03:50
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友
觸發(fā)器是一種特殊類型的存儲(chǔ)過(guò)程,它不同于之前的我們介紹的存儲(chǔ)過(guò)程.觸發(fā)器主要是通過(guò)事件進(jìn)行觸發(fā)被自動(dòng)調(diào)用執(zhí)行的。而存儲(chǔ)過(guò)程可以通過(guò)存儲(chǔ)過(guò)程的名稱被調(diào)用。本文給大家介紹SQLSever中的觸發(fā)器基本語(yǔ)法與作用,感興趣的朋友一起學(xué)習(xí)吧
 

什么是觸發(fā)器?

觸發(fā)器是在對(duì)表進(jìn)行插入、更新或刪除操作時(shí)自動(dòng)執(zhí)行的存儲(chǔ)過(guò)程。 觸發(fā)器對(duì)表進(jìn)行插入、更新、刪除的時(shí)候會(huì)自動(dòng)執(zhí)行的特殊存儲(chǔ)過(guò)程。觸發(fā)器一般用在check約束更加復(fù)雜的約束上面。觸發(fā)器和普通的存儲(chǔ)過(guò)程的區(qū)別是:觸發(fā)器是當(dāng)對(duì)某一個(gè)表進(jìn)行操作。諸如:update、insert、delete這些操作的時(shí)候,系統(tǒng)會(huì)自動(dòng)調(diào)用執(zhí)行該表上對(duì)應(yīng)的觸發(fā)器。SQL Server 2005中觸發(fā)器可以分為兩類:DML觸發(fā)器和DDL觸發(fā)器,其中DDL觸發(fā)器它們會(huì)影響多種數(shù)據(jù)定義語(yǔ)言語(yǔ)句而激發(fā),這些語(yǔ)句有create、alter、drop語(yǔ)句。

SQL Server為每個(gè)觸發(fā)器都創(chuàng)建了兩個(gè)專用表﹕Inserted表和Deleted表。

觸發(fā)器通常用于強(qiáng)制業(yè)務(wù)規(guī)則

觸發(fā)器是一種高級(jí)約束,可以定義比用CHECK 約束更為復(fù)雜的約束 :可執(zhí)行復(fù)雜的SQL語(yǔ)句(if/while/case)、可引用其它

表中的列

觸發(fā)器定義在特定的表上,與表相關(guān)。

自動(dòng)觸發(fā)執(zhí)行

不能直接調(diào)用

是一個(gè)事務(wù)(可回滾)使用觸發(fā)器的好處觸發(fā)器可通過(guò)數(shù)據(jù)庫(kù)中的相關(guān)表實(shí)現(xiàn)級(jí)聯(lián)更改,不過(guò),通過(guò)級(jí)聯(lián)引用完整性約束可以更有效地執(zhí)行這些更改。觸發(fā)器可以強(qiáng)制比用CHECK約束定義的約束更為復(fù)雜的約束。與 CHECK 約束不同,觸發(fā)器可以引用其它表中的列。例如,觸發(fā)器可以使用另一個(gè)表中的 SELECT 比較插入或更新的數(shù)據(jù),以及執(zhí)行其它操作,如修改數(shù)據(jù)或顯示用戶定義錯(cuò)誤信息。觸發(fā)器也可以評(píng)估數(shù)據(jù)修改前后的表狀態(tài),并根據(jù)其差異采取對(duì)策。一個(gè)表中的多個(gè)同類觸發(fā)器(INSERT、UPDATE 或 DELETE)允許采取多個(gè)不同的對(duì)策以響應(yīng)同一個(gè)修改語(yǔ)句。

DML觸發(fā)器分為:

1、 after觸發(fā)器(之后觸發(fā))

a、 insert觸發(fā)器

b、 update觸發(fā)器

c、 delete觸發(fā)器

UPDATE 觸發(fā)器創(chuàng)建觸發(fā)的語(yǔ)法

CREATE TRIGGER trigger_nameON table_name[WITH ENCRYPTION]FOR [DELETE, INSERT, UPDATE]AST-SQL語(yǔ)句GO

注意:WITH ENCRYPTION表示加密觸發(fā)器定義的SQL文本 DELETE, INSERT, UPDATE指定觸發(fā)器的類型 insert 觸發(fā)器示例

/*創(chuàng)建insert觸發(fā)器,在上網(wǎng)記錄表recordInfo上創(chuàng)建插入觸發(fā)器*/create trigger tr_insert_recordInfoon recordInfofor insertas/*定義變量,用于臨時(shí)存儲(chǔ)插入的會(huì)員號(hào)、電腦編號(hào)和卡的編號(hào)*/declare @cardId char()declare @PCId intdeclare @CardNumber char()/*從inserted臨時(shí)表中獲取插入的記錄行的信息,包括電腦的編號(hào)、卡的編號(hào)*/select @PCId=PCId,@cardId=CardId from inserted/*根據(jù)電腦編號(hào)修改電腦的使用狀態(tài)*/update PCInfo set PCUse= where PCId=@PCId/*根據(jù)卡的編號(hào)查詢會(huì)員號(hào)*/select @CardNumber=CardNumber from cardinfo where CardId=@cardid/*顯示上機(jī)成功的信息*/print '上機(jī)成功!會(huì)員號(hào)是:'+@CardNumber+'機(jī)器號(hào)是:'+convert(char(),@PCId)go----插入測(cè)試數(shù)據(jù),會(huì)員號(hào)為的上機(jī)set nocount on --不顯示sql語(yǔ)句影響的記錄行數(shù)declare @CardId int ---聲明一個(gè)存儲(chǔ)卡的編號(hào)的變量---根據(jù)會(huì)員號(hào)查處卡的編號(hào)select @cardId=cardid from cardinfo where cardNumber='c' ---向recordInfo表中插入一條記錄信息,卡的編號(hào)、電腦編號(hào)和上機(jī)時(shí)間insert into recordInfo(cardId,PCId,beginTime) values(@cardId,,getDate())----查看結(jié)果select * from recordInfoselect * from PCInfo

update觸發(fā)器示例

---創(chuàng)建delete觸發(fā)器,在上網(wǎng)記錄表RecordInfo上創(chuàng)建刪除觸發(fā)器create trigger tr_delete_recordInfoon recordInfofor deleteasif exists(select * from sysobjects where name='backRecordInfo')----如果backrecordInfo表存在,就添加記錄即可insert into backRecordInfo select * from deletedelse----創(chuàng)建backRecordInfo表,從deleted中獲取被刪除的數(shù)據(jù)select * into backRecordInfo from deletedprint'backRecordInfo表備份數(shù)據(jù)成功,備份表中的數(shù)據(jù)為:'select * from backRecordInfogo-------關(guān)鍵代碼----------測(cè)試delete觸發(fā)器,刪除數(shù)據(jù)set nocount ondelete from recordInfo---查看結(jié)果print'記錄表中的數(shù)據(jù)為:'select * from recordInfo

delete觸發(fā)器示例

-------關(guān)鍵代碼------create trigger tr_update_recordInfoon recordInfofor updateasdeclare @beforePCId intdeclare @afterPCId intselect @beforePCId =PCId from deletedselect @afterPCId=PCID from inserted---根據(jù)電腦編號(hào)修改使用狀態(tài)--------根據(jù)以前使用的電腦編號(hào)把電腦的使用狀態(tài)改為:update PCInfo set PCUse= where PCId=@beforePCId---根據(jù)現(xiàn)在使用的電腦編號(hào)把電腦的使用狀態(tài)改為:update PCInfo set PCUse= where PCId=@afterPCId----顯示電腦換機(jī)成功print'換機(jī)成功!從'+convert(varchar(),@beforePCId)+'號(hào)電腦換到'+convert(varchar(),@afterPCId)+'號(hào)電腦'go/*測(cè)試update觸發(fā)器,修改電腦編號(hào)*/--顯示更改前,記錄表中的數(shù)據(jù)print'更改前,記錄表中的數(shù)據(jù)'select * from recordInfo--顯示更改前,電腦表中的數(shù)據(jù)print'更改前,電腦表中的數(shù)據(jù)'select * from PCInfoset nocount on---把電腦號(hào)為的改為update recordInfo set PCId= where PCId= ---查看結(jié)果print'更改后,記錄表中的數(shù)據(jù)'select * from recordInfoprint'更改后,電腦表中的數(shù)據(jù)'select * from PCInfo

instead of觸發(fā)器的使用 instead of觸發(fā)器的使用范圍,instead of 觸發(fā)器可以同時(shí)在數(shù)據(jù)表和視圖中使用。通常在以下幾種情況下,建議使用instead of觸發(fā)器: 數(shù)據(jù)庫(kù)里的數(shù)據(jù)禁止修改:例如電信部門的通話記錄是不能修改的,一旦修改,則通話費(fèi)用的計(jì)數(shù)將不準(zhǔn)確。 有可能要回滾修改的SQL語(yǔ)句 在視圖中使用觸發(fā)器 用自己的方式去修改數(shù)據(jù) instead of觸發(fā)器示例

---創(chuàng)建update觸發(fā)器,在上網(wǎng)記錄表recordInfo上創(chuàng)建修改(列)觸發(fā)器create trigger tr_updateColum1_recordInfoon recordInfoinstead of insertasdeclare @cardbalance int --聲明用于存儲(chǔ)用戶余額的變量declare @CardId int --聲明用于存儲(chǔ)用戶卡的編號(hào)的變量declare @PCId int --聲明用于存儲(chǔ)電腦編號(hào)的變量---inserted臨時(shí)表中獲取插入的記錄行信息,包括電腦編號(hào)、卡的編號(hào)select @cardId=cardId,@PCId=PCId from insertedselect @cardbalance=cardBalance from cardInfo where CardId=@CardIdprint'您的余額為:'+convert(varchar(10),@cardBalance) ---打印余額信息if(@cardBalance<2) ---判斷余額多少,看能否正常上機(jī)print'余額小于元,不能上機(jī)。請(qǐng)盡快充值!'else----根據(jù)電腦的編號(hào)修改電腦的使用狀態(tài)更改為正在使用update PCInfo set PCUse=1 where PCId=@PCId----向recordInfo表插入上機(jī)記錄insert into recordInfo(cardId,PCId,beginTime)values(@CardId,@PCId,getdate())print'上機(jī)成功'-------關(guān)鍵代碼------set nocount ondeclare @cardId int ---聲明一個(gè)存儲(chǔ)卡的編號(hào)的變量---根據(jù)會(huì)員號(hào)查出卡的編號(hào)select @cardId=cardId from cardInfo where cardNumber='c001'----向recordInfo表中插入一條記錄信息,卡的編號(hào)、電腦的編號(hào)和上機(jī)時(shí)間insert into recordInfo(cardId,PCId,beginTime)values(@cardId,1,getdate())select * from recordInfoselect * from PCInfo

以上所述是小編給大家介紹的SQLSever中的觸發(fā)器基本語(yǔ)法與作用的相關(guān)內(nèi)容,希望對(duì)大家有所幫助!



注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到MSSQL教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 永清县| 拜泉县| 瓮安县| 淮北市| 高雄市| 台山市| 从化市| 太仓市| 东辽县| 布拖县| 友谊县| 西安市| 明光市| 泸定县| 扎囊县| 长治市| 五常市| 利辛县| 塘沽区| 墨玉县| 潞西市| 同仁县| 界首市| 大港区| 马尔康县| 上犹县| 鸡西市| 东乡县| 潮州市| 通化县| 新乐市| 太仓市| 古交市| 绩溪县| 扬中市| 循化| 西平县| 新邵县| 茂名市| 堆龙德庆县| 体育|