亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > SQL Server > 正文

SQLServer觸發器創建、刪除、修改、查看示例代碼

2024-08-31 00:58:37
字體:
來源:轉載
供稿:網友
一: 觸發器是一種特殊的存儲過程﹐它不能被顯式地調用﹐而是在往表中插入記錄﹑更新記錄或者刪除記錄時被自動地激活。所以觸發器可以用來實現對表實施復雜的完整性約束。

二: SQL Server為每個觸發器都創建了兩個專用表:Inserted表和Deleted表。這兩個表。

一: 觸發器是一種特殊的存儲過程﹐它不能被顯式地調用﹐而是在往表中插入記錄﹑更新記錄或者刪除記錄時被自動地激活。所以觸發器可以用來實現對表實施復雜的完整性約`束。

二: SQL Server為每個觸發器都創建了兩個專用表:Inserted表和Deleted表。這兩個表由系統來維護﹐它們存在于內存中而不是在數據庫中。這兩個表的結構總是與被該觸發器作用的表的結構相同。觸發器執行 完成后﹐與該觸發器相關的這兩個表也被刪除。
Deleted表存放由于執行Delete或Update語句而要從表中刪除的所有行。
Inserted表存放由于執行Insert或Update語句而要向表中插入的所有行。
三:Instead of 和 After觸發器
SQL Server2000提供了兩種觸發器:Instead of 和After 觸發器。這兩種觸發器的差別在于他們被激活的同:

Instead of觸發器用于替代引起觸發器執行的T-SQL語句。除表之外﹐Instead of 觸發器也可以用于視圖﹐用來擴展視圖可以支持的更新操作。

After觸發器在一個Insert,Update或Deleted語句之后執行﹐進行約束檢查等動作都在After觸發器被激活之前發生。After觸發器只能用于表。

一個表或視圖的每一個修改動作(insert,update和delete)都可以有一個instead of 觸發器﹐一個表的每個修改動作都可以有多個After觸發器。
四:觸發器的執行過程
如果一個Insert﹑update或者delete語句違反了約束﹐那幺After觸發器不會執行﹐因為對約束的檢查是在After觸發器被激動之前發生的。所以After觸發器不能超越約束。

Instead of 觸發器可以取代激發它的操作來執行。它在Inserted表和Deleted表剛剛建立﹐其它任何操作還沒有發生時被執行。因為Instead of 觸發器在約束之前執行﹐所以它可以對約束進行一些預處理。

五:使用T-SQL語句來創建觸發器

基本語句如下:
create trigger trigger_name
on {table_name | view_name}
{for | After | Instead of }
[ insert, update,delete ]
as
sql_statement

六:刪除觸發器:

基本語句如下:

drop trigger trigger_name

七:查看數據庫中已有觸發器:

-- 查看數據庫已有觸發器
use jxcSoftware
go
select * from sysobjects where xtype='TR'

-- 查看單個觸發器
exec sp_helptext '觸發器名'

八:修改觸發器:

基本語句如下:
alter trigger trigger_name
on {table_name | view_name}
{for | After | Instead of }
[ insert, update,delete ]
as
sql_statement

九:相關示例:
1:在Orders表中建立觸發器﹐當向Orders表中插入一條訂單記錄時﹐檢查goods表的貨品狀態status是否為1(正在整理)﹐是﹐則不能往Orders表加入該訂單。
create trigger orderinsert
on orders
after insert
as
if (select status from goods,inserted
where goods.name=inserted.goodsname)=1
begin
print 'the goods is being processed'
print 'the order cannot be committed'
rollback transaction --回滾﹐避免加入
end
2:在Orders表建立一個插入觸發器﹐在添加一條訂單時﹐減少Goods表相應的貨品記錄中的庫存。
create trigger orderinsert1
on orders
after insert
as
update goods set storage=storage-inserted.quantity
from goods,inserted
where
goods.name=inserted.goodsname
3:在Goods表建立刪除觸發器﹐實現Goods表和Orders表的級聯刪除。
create trigger goodsdelete
on goods
after delete
as
delete from orders
where goodsname in
(select name from deleted)
4:在Orders表建立一個更新觸發器﹐監視Orders表的訂單日期(OrderDate)列﹐使其不能手工修改.
create trigger orderdateupdate
on orders
after update
as
if update(orderdate)
begin
raiserror(' orderdate cannot be modified',10,1)
rollback transaction
end
5:在Orders表建立一個插入觸發器﹐保證向Orders表插入的貨品名必須要在Goods表中一定存在。
create trigger orderinsert3
on orders
after insert
as
if (select count(*) from goods,inserted where goods.name=inserted.goodsname)=0
begin
print ' no entry in goods for this order'
rollback transaction
end

6:Orders表建立一個插入觸發器,保證向Orders表插入的貨品信息要在Order表中添加

alter trigger addOrder
on Orders
for insert
as
insert into Order
select inserted.Id, inserted.goodName,inserted.Number from inserted
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
中文字幕无线精品亚洲乱码一区| 欧美精品福利在线| 成人免费大片黄在线播放| 久久天天躁狠狠躁夜夜躁2014| 最近2019中文字幕大全第二页| 韩国一区二区电影| 国产精品成人免费视频| 91精品国产九九九久久久亚洲| 亚洲国产精品成人av| 欧美激情一区二区三级高清视频| 亚洲午夜性刺激影院| 亚洲精品丝袜日韩| 人妖精品videosex性欧美| 亚洲第一免费网站| 日韩精品中文字幕在线| www国产亚洲精品久久网站| 亚洲成人免费在线视频| 亚洲国内精品在线| 精品国内自产拍在线观看| 亚洲男人av电影| 国产精品户外野外| 亚洲自拍另类欧美丝袜| 最近2019中文字幕mv免费看| 日本久久久久久久| 久久久成人av| 亚洲天堂开心观看| 日韩国产高清污视频在线观看| 91极品视频在线| 中文字幕在线精品| 91精品久久久久久久久久久| 日韩av理论片| 黑人极品videos精品欧美裸| 欧美性猛交xxxx乱大交| 国模精品视频一区二区| 国产精品盗摄久久久| 亚洲欧美中文日韩v在线观看| 亚洲午夜精品久久久久久性色| 国产欧美在线观看| 91精品视频在线| 日本一区二区三区四区视频| 日韩国产欧美精品一区二区三区| 久久av红桃一区二区小说| 成人精品一区二区三区电影免费| 蜜臀久久99精品久久久久久宅男| 在线国产精品视频| 在线电影欧美日韩一区二区私密| 亚洲精品美女在线观看| 亚洲精品v天堂中文字幕| 久久人人爽亚洲精品天堂| 九九热精品视频| 国产精品久久久久久久天堂| 亚洲女人天堂av| 欧美孕妇孕交黑巨大网站| 色老头一区二区三区在线观看| 欧美大片va欧美在线播放| 亚洲精品之草原avav久久| 亚洲精品黄网在线观看| 97婷婷大伊香蕉精品视频| 欧美在线激情视频| 91美女福利视频高清| 国产精品免费一区| 欧美韩日一区二区| 亚洲精品视频播放| 日韩av电影手机在线观看| 日韩在线观看免费全集电视剧网站| 欧美精品久久久久久久免费观看| 亚洲自拍另类欧美丝袜| 成人a在线视频| 97在线观看视频国产| 久久久亚洲欧洲日产国码aⅴ| 久久久极品av| 亚洲热线99精品视频| 久久偷看各类女兵18女厕嘘嘘| 精品福利在线观看| 不卡毛片在线看| 第一福利永久视频精品| 国产精品第一区| 久久免费观看视频| 国产精品九九久久久久久久| 精品毛片三在线观看| 日韩hd视频在线观看| 国内外成人免费激情在线视频网站| 大胆欧美人体视频| 奇米成人av国产一区二区三区| 亚洲第一中文字幕| 欧美日韩日本国产| 亚洲人成网在线播放| 中文字幕久久久av一区| 久久91亚洲人成电影网站| 国产精品久久不能| 亚洲大胆人体av| 亚洲一区中文字幕在线观看| 午夜欧美不卡精品aaaaa| 久久久久久久成人| 日韩一区二区欧美| 久久精品夜夜夜夜夜久久| 九九视频直播综合网| 日本成人免费在线| 欧美性猛交xxxx富婆| 性色av一区二区三区在线观看| 九九热精品视频在线播放| 川上优av一区二区线观看| 日韩欧美在线视频免费观看| 国产一区二区精品丝袜| 亚洲天堂精品在线| 亚洲人成电影网站色www| 另类专区欧美制服同性| 亚洲天堂av在线播放| 久久九九国产精品怡红院| 亚洲欧洲国产伦综合| 亚洲精品美女在线观看播放| 国模极品一区二区三区| 欧美精品18videosex性欧美| 国产激情999| 国产精品色午夜在线观看| 欧美日韩国产在线播放| 91精品国产成人| 国产精品稀缺呦系列在线| 精品人伦一区二区三区蜜桃网站| 久久久精品中文字幕| 亚洲精品一区二三区不卡| 欧洲午夜精品久久久| 国产成人在线播放| 97视频在线观看视频免费视频| 久久久久久亚洲精品不卡| 精品av在线播放| 国产精品久久久亚洲| 国产在线不卡精品| 欧美成人免费va影院高清| 亚洲天堂第一页| 久久久久北条麻妃免费看| 亚洲成人性视频| 性欧美xxxx交| 另类少妇人与禽zozz0性伦| 午夜免费久久久久| 欧美高清一级大片| 97国产成人精品视频| 日韩高清a**址| 51久久精品夜色国产麻豆| 久久福利网址导航| 91av福利视频| 国产成人精品国内自产拍免费看| 国产成人鲁鲁免费视频a| 久久久国产精品视频| 亚洲国产一区二区三区四区| 欧美激情2020午夜免费观看| 欧美成人亚洲成人日韩成人| 视频直播国产精品| 26uuu日韩精品一区二区| 国模私拍一区二区三区| 亚洲午夜色婷婷在线| 国产精品男女猛烈高潮激情| 日本人成精品视频在线| 国内精品免费午夜毛片| 欧美性感美女h网站在线观看免费| 国产免费久久av| 亚洲精品永久免费精品| 91久久久久久久久久| 激情懂色av一区av二区av| 国产成人一区二区三区电影| 亚洲美女久久久| 成人精品一区二区三区电影免费| 国产精品久久97| 日韩欧美福利视频|