真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

SqlServer中如何使用觸發(fā)器-創(chuàng)新互聯(lián)

本篇文章為大家展示了Sql Server中如何使用觸發(fā)器,內(nèi)容簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過(guò)這篇文章的詳細(xì)介紹希望你能有所收獲。

成都創(chuàng)新互聯(lián)公司服務(wù)項(xiàng)目包括鹽湖網(wǎng)站建設(shè)、鹽湖網(wǎng)站制作、鹽湖網(wǎng)頁(yè)制作以及鹽湖網(wǎng)絡(luò)營(yíng)銷策劃等。多年來(lái),我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢(shì)、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,鹽湖網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到鹽湖省份的部分城市,未來(lái)相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!

Sql Server為每個(gè)觸發(fā)器都創(chuàng)建了兩個(gè)專用表:Inserted表和Deleted表。這兩個(gè)表由系統(tǒng)來(lái)維護(hù),它們存在于內(nèi)存中而不是數(shù)據(jù)庫(kù)中。這兩個(gè)表的結(jié)構(gòu)總是與被該觸發(fā)器作用的表的結(jié)構(gòu)相同,觸發(fā)器執(zhí)行完成后,與該觸發(fā)器相關(guān)的這兩個(gè)表也被刪除。

對(duì)表的操作


Inserted邏輯表

Deleted邏輯表

增加記錄(insert)

存放增加的記錄

無(wú)

刪除記錄(delete)

無(wú)

存放被刪除的記錄

修改記錄(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ā)順序不確定,并且無(wú)法控制。

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ā)器:

createtriggertrigger_name

on{table_name|view_name}

{for|After|Insteadof}

[insert,update,delete]

as

sql_statement

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

droptriggertrigger_name

3、查看數(shù)據(jù)庫(kù)中已有的觸發(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è)資訊頻道。


當(dāng)前名稱:SqlServer中如何使用觸發(fā)器-創(chuàng)新互聯(lián)
文章出自:http://weahome.cn/article/ceieds.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部