本篇文章為大家展示了Sql Server中如何使用觸發(fā)器,內(nèi)容簡明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。
我們提供的服務(wù)有:成都網(wǎng)站設(shè)計(jì)、做網(wǎng)站、微信公眾號(hào)開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、平泉ssl等。為1000多家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的平泉網(wǎng)站制作公司
Sql Server為每個(gè)觸發(fā)器都創(chuàng)建了兩個(gè)專用表:Inserted表和Deleted表。這兩個(gè)表由系統(tǒng)來維護(hù),它們存在于內(nèi)存中而不是數(shù)據(jù)庫中。這兩個(gè)表的結(jié)構(gòu)總是與被該觸發(fā)器作用的表的結(jié)構(gòu)相同,觸發(fā)器執(zhí)行完成后,與該觸發(fā)器相關(guān)的這兩個(gè)表也被刪除。
對(duì)表的操作
Inserted邏輯表
Deleted邏輯表
增加記錄(insert)
存放增加的記錄
無
刪除記錄(delete)
無
存放被刪除的記錄
修改記錄(update)
存放更新后的記錄
存放更新前的記錄
三、for、after、instead of觸發(fā)器
after:觸發(fā)器在觸發(fā)它們的語句完成后執(zhí)行。如果該語句因錯(cuò)誤而失敗,觸發(fā)器將不會(huì)執(zhí)行。不能為視圖指定after觸發(fā)器,只能為表指定該觸發(fā)器??梢詾槊總€(gè)觸發(fā)操作(insert、update、delete)指定多個(gè)after觸發(fā)器。如果表有多個(gè)after觸發(fā)器,可使用sp_settriggerorder定義哪個(gè)after觸發(fā)器最先激發(fā),哪個(gè)最后激發(fā)。除第一個(gè)和最后一個(gè)觸發(fā)器外,所有其他的after觸發(fā)器的激發(fā)順序不確定,并且無法控制。
for:等同于after
instead of:該觸發(fā)器代替觸發(fā)操作執(zhí)行??稍诒砗鸵晥D上指定instead of觸發(fā)器。只能為每個(gè)觸發(fā)操作(insert、update、delete)定義一個(gè)instead of觸發(fā)器。instead of觸發(fā)器可用于對(duì)insert和update語句中提供的數(shù)據(jù)值執(zhí)行增強(qiáng)的完整性檢查。
四、 觸發(fā)器的使用
1、創(chuàng)建觸發(fā)器:
createtriggertrigger_name
on{table_name|view_name}
{for|After|Insteadof}
[insert,update,delete]
as
sql_statement
2、刪除觸發(fā)器:
droptriggertrigger_name
3、查看數(shù)據(jù)庫中已有的觸發(fā)器:
select*fromsysobjectswherextype='TR'
4、查看單個(gè)觸發(fā)器:
execsp_helptext'觸發(fā)器名'
5、修改觸發(fā)器:
altertriggertrigger_name
on{table_name|view_name}
{for|After|Insteadof}
[insert,update,delete]
as
sql_statement
五、觸發(fā)器的實(shí)例
1、在Orders表中建立觸發(fā)器,當(dāng)向Orders表中插入一條記錄時(shí),檢查goods表的貨品狀態(tài)status是否為1。是,則不能往Orders表加入該訂單。
if(object_id('tgr_orders_insert','tr')isnotnull)droptrigger[tgr_orders_insert];gocreatetrigger[tgr_orders_insert]on[orders]afterinsertasif(select[status]from[goods],[inserted]where[goods].name=[inserted].name)=1beginprint'thegoodsisbeingprocessed'print'theordercannotbecommitted'rollbacktransaction--回滾﹐避免加入
end
上述內(nèi)容就是Sql Server中如何使用觸發(fā)器,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
網(wǎng)頁標(biāo)題:SqlServer中如何使用觸發(fā)器
文章轉(zhuǎn)載:http://muchs.cn/article10/jpisgo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供商城網(wǎng)站、App開發(fā)、品牌網(wǎng)站制作、網(wǎng)站制作、App設(shè)計(jì)、關(guān)鍵詞優(yōu)化
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)