91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Sql Server中如何使用觸發器

發布時間:2021-08-04 15:45:18 來源:億速云 閱讀:142 作者:Leah 欄目:數據庫

本篇文章為大家展示了Sql Server中如何使用觸發器,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

Sql Server為每個觸發器都創建了兩個專用表:Inserted表和Deleted表。這兩個表由系統來維護,它們存在于內存中而不是數據庫中。這兩個表的結構總是與被該觸發器作用的表的結構相同,觸發器執行完成后,與該觸發器相關的這兩個表也被刪除。

對表的操作

Inserted邏輯表

Deleted邏輯表

增加記錄(insert)

存放增加的記錄

刪除記錄(delete)

存放被刪除的記錄

修改記錄(update)

存放更新后的記錄

存放更新前的記錄

三、for、after、instead of觸發器

after:觸發器在觸發它們的語句完成后執行。如果該語句因錯誤而失敗,觸發器將不會執行。不能為視圖指定after觸發器,只能為表指定該觸發器。可以為每個觸發操作(insert、update、delete)指定多個after觸發器。如果表有多個after觸發器,可使用sp_settriggerorder定義哪個after觸發器最先激發,哪個最后激發。除第一個和最后一個觸發器外,所有其他的after觸發器的激發順序不確定,并且無法控制。

for:等同于after

instead of:該觸發器代替觸發操作執行。可在表和視圖上指定instead of觸發器。只能為每個觸發操作(insert、update、delete)定義一個instead of觸發器。instead of觸發器可用于對insert和update語句中提供的數據值執行增強的完整性檢查。

四、 觸發器的使用

1、創建觸發器:

createtriggertrigger_name

on{table_name|view_name}

{for|After|Insteadof}

[insert,update,delete]

as

sql_statement

2、刪除觸發器:

droptriggertrigger_name

3、查看數據庫中已有的觸發器:

select*fromsysobjectswherextype='TR'

4、查看單個觸發器:

execsp_helptext'觸發器名'

5、修改觸發器:

altertriggertrigger_name

on{table_name|view_name}

{for|After|Insteadof}

[insert,update,delete]

as

sql_statement

五、觸發器的實例

1、在Orders表中建立觸發器,當向Orders表中插入一條記錄時,檢查goods表的貨品狀態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

上述內容就是Sql Server中如何使用觸發器,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

泾川县| 图木舒克市| 阿克苏市| 大竹县| 桂林市| 若羌县| 隆化县| 织金县| 正阳县| 安国市| 湄潭县| 西贡区| 双鸭山市| 通海县| 承德市| 舞钢市| 苗栗县| 舞阳县| 白银市| 华蓥市| 广德县| 青阳县| 安乡县| 义马市| 福清市| 象山县| 鄂托克旗| 抚松县| 彩票| 美姑县| 成武县| 宁陵县| 金湖县| 班玛县| 廉江市| 高邮市| 西藏| 湖口县| 沙田区| 临海市| 江油市|