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

首頁 > 數(shù)據庫 > SQL Server > 正文

判斷觸發(fā)器正在處理的是插入,刪除還是更新觸發(fā)

2024-08-31 00:57:51
字體:
來源:轉載
供稿:網友
但是有時候,可以視看處進邏輯程度,可以把三者寫成一個觸發(fā)器,只是在其中稍作判斷而已。

你可以根據從下面方法判斷觸發(fā)器是是處理了插入,刪除還是更新觸發(fā)的:

復制代碼 代碼如下:


--宣告兩個變量
DECLARE @D BIT = 0
DECLARE @I BIT = 0

--如果在DELETED內部臨時觸發(fā)表找到記錄,說明舊數(shù)據被刪除
IF EXISTS(SELECT TOP 1 1 FROM DELETED)
SET @D = 1

--如果在INSERTED內部臨時觸發(fā)表找到記錄,說明有新數(shù)據插入
IF EXISTS(SELECT TOP 1 1 FROM INSERTED)
SET @I = 1

--如果兩個表都有記錄,說明觸發(fā)器是執(zhí)行更新觸發(fā)
IF @I = 1 AND @D = 1
PRINT(N'更新。')

--如果變量@I值被變更為1,而變量@D沒有變更,說明觸發(fā)器是執(zhí)行插入觸發(fā)
IF @I = 1 AND @D = 0
PRINT(N'插入')

--下面判斷成立,說明說明觸發(fā)器是執(zhí)行刪除觸發(fā)
IF @I = 0 AND @D = 1
PRINT(N'刪除')



另外有關兩個內部臨時觸發(fā)表,觸發(fā)器的Inserted表和Deleted表

觸發(fā)器有兩個虛擬表,Inserted表和Deleted表,這兩個表在不同操作情況之下,表中的數(shù)據狀態(tài)可不一樣。
一、插入操作(INSERT)時:Inserted表有數(shù)據,Deleted表無數(shù)據。
二、更新操作(UPDATE)時:Inserted表有數(shù)據(新數(shù)據),Deleted表有數(shù)據(舊數(shù)據)。
三、刪除操作(DELETE)時:Inserted表無數(shù)據,Deleted表有數(shù)據。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 崇信县| 察隅县| 安宁市| 扬中市| 肇源县| 阿坝| 嘉义县| 崇信县| 汤阴县| 苏尼特右旗| 壤塘县| 酉阳| 台州市| 额尔古纳市| 丘北县| 建昌县| 凯里市| 布拖县| 左权县| 嘉善县| 盘锦市| 舟山市| 元氏县| 特克斯县| 屏东县| 会昌县| 库尔勒市| 新化县| 和顺县| 义马市| 讷河市| 奉节县| 五寨县| 赣州市| 宜宾县| 武胜县| 长海县| 汾阳市| 从江县| 甘洛县| 甘洛县|