濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > Sql Server觸發(fā)器的使用

Sql Server觸發(fā)器的使用

熱門標(biāo)簽:400電話申請(qǐng)需要開戶費(fèi)嗎 溫州語(yǔ)音外呼系統(tǒng)代理 南京電銷外呼系統(tǒng)運(yùn)營(yíng)商 智能語(yǔ)音外呼系統(tǒng)哪個(gè)牌子好 威海智能語(yǔ)音外呼系統(tǒng) 山西語(yǔ)音外呼系統(tǒng)價(jià)格 重慶防封電銷機(jī)器人供應(yīng)商 北京辦理400電話多少 西安青牛防封電銷卡
 Sql Server為每個(gè)觸發(fā)器都創(chuàng)建了兩個(gè)專用表:Inserted表和Deleted表。這兩個(gè)表由系統(tǒng)來維護(hù),它們存在于內(nèi)存中而不是數(shù)據(jù)庫(kù)中。這兩個(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ā)它們的語(yǔ)句完成后執(zhí)行。如果該語(yǔ)句因錯(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語(yǔ)句中提供的數(shù)據(jù)值執(zhí)行增強(qiáng)的完整性檢查。

四、 觸發(fā)器的使用

1、創(chuàng)建觸發(fā)器:

create trigger trigger_name

on {table_name | view_name} 

{for| After | Instead of }

[ insert, update,delete ]

as

sql_statement 

2、刪除觸發(fā)器:

drop trigger trigger_name 

3、查看數(shù)據(jù)庫(kù)中已有的觸發(fā)器:

 select * from sysobjects where xtype='TR'

4、查看單個(gè)觸發(fā)器:

exec sp_helptext '觸發(fā)器名' 

5、修改觸發(fā)器:

alter trigger trigger_name

on {table_name | view_name} 

{for| After | Instead of }

[ 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'is not null)
    drop trigger [tgr_orders_insert];
go
create trigger [tgr_orders_insert]
on [orders]
after insert
as 
if (select [status] from [goods],[inserted] where [goods].name=[inserted].name)=1
begin
    print 'the goods is being processed'
    print 'the order cannot be committed'    
    rollback transaction   --回滾﹐避免加入

end 

您可能感興趣的文章:
  • SQL Server 觸發(fā)器 表的特定字段更新時(shí),觸發(fā)Update觸發(fā)器
  • sqlserver 禁用觸發(fā)器和啟用觸發(fā)器的語(yǔ)句
  • SQLServer觸發(fā)器創(chuàng)建、刪除、修改、查看示例代碼
  • 用sql腳本創(chuàng)建sqlserver數(shù)據(jù)庫(kù)觸發(fā)器范例語(yǔ)句
  • SQL Server觸發(fā)器及觸發(fā)器中的事務(wù)學(xué)習(xí)
  • 在登錄觸發(fā)器錯(cuò)誤情況下連接SQL Server的方法
  • sqlserver 觸發(fā)器教程
  • sqlserver 觸發(fā)器實(shí)例代碼
  • sqlserver中觸發(fā)器+游標(biāo)操作實(shí)現(xiàn)
  • SQL SERVER 觸發(fā)器介紹
  • SQL SERVER中各類觸發(fā)器的完整語(yǔ)法及參數(shù)說明
  • SQLSever中的觸發(fā)器基本語(yǔ)法與作用

標(biāo)簽:黃山 河源 金昌 貸款群呼 新余 濟(jì)寧 中衛(wèi) 宜春

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Sql Server觸發(fā)器的使用》,本文關(guān)鍵詞  Sql,Server,觸發(fā)器,的,使用,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Sql Server觸發(fā)器的使用》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于Sql Server觸發(fā)器的使用的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    遂溪县| 岳阳市| 双辽市| 麟游县| 将乐县| 青冈县| 祁东县| 衢州市| 鄂伦春自治旗| 盐亭县| 长葛市| 马尔康县| 唐海县| 馆陶县| 浦县| 蒙山县| 定边县| 眉山市| 红河县| 金乡县| 贡山| 蛟河市| 彭山县| 天气| 桦南县| 靖宇县| 陇西县| 林周县| 南靖县| 山阴县| 镇康县| 太白县| 商河县| 吕梁市| 砚山县| 涡阳县| 枣阳市| 屏东县| 蒙山县| 介休市| 故城县|