• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆-15  評論-5  文章-0  trackbacks-0
            1、觸發(fā)器

            定義: 何為觸發(fā)器?在SQL Server里面也就是對某一個表的一定的操作,觸發(fā)某種條件,從而執(zhí)行的一段程序。觸發(fā)器是一個特殊的存儲過程。
            常見的觸發(fā)器有三種:分別應(yīng)用于Insert , Update , Delete 事件。(SQL Server 2000定義了新的觸發(fā)器,這里不提)

            我為什么要使用觸發(fā)器?比如,這么兩個表:

            Create Table Student( --學(xué)生表
            StudentID int primary key, --學(xué)號
            ....
            )

            Create Table BorrowRecord( --學(xué)生借書記錄表
            BorrowRecord int identity(1,1), --流水號
            StudentID int , --學(xué)號
            BorrowDate datetime, --借出時間
            ReturnDAte Datetime, --歸還時間
            ...
            )

            用到的功能有:
            1.如果我更改了學(xué)生的學(xué)號,我希望他的借書記錄仍然與這個學(xué)生相關(guān)(也就是同時更改借書記錄表的學(xué)號);
            2.如果該學(xué)生已經(jīng)畢業(yè),我希望刪除他的學(xué)號的同時,也刪除它的借書記錄。
            等等。

            這時候可以用到觸發(fā)器。對于1,創(chuàng)建一個Update觸發(fā)器:

            Create Trigger truStudent
            On Student
            for Update
            As
            if Update(StudentID)
            begin

            Update BorrowRecord
            Set StudentID=i.StudentID
            From BorrowRecord br , Deleted d ,Inserted i
            Where br.StudentID=d.StudentID

            end

            理解觸發(fā)器里面的兩個臨時的表:Deleted , Inserted 。注意Deleted 與Inserted分別表示觸發(fā)事件的表“舊的一條記錄”和“新的一條記錄”。
            一個Update 的過程可以看作為:生成新的記錄到Inserted表,復(fù)制舊的記錄到Deleted表,然后刪除Student記錄并寫入新紀(jì)錄。

            對于2,創(chuàng)建一個Delete觸發(fā)器
            Create trigger trdStudent
            On Student
            for Delete
            As
            Delete BorrowRecord
            From BorrowRecord br , Delted d
            Where br.StudentID=d.StudentID

            從這兩個例子我們可以看到了觸發(fā)器的關(guān)鍵:A.2個臨時的表;B.觸發(fā)機(jī)制。
            這里我們只講解最簡單的觸發(fā)器。復(fù)雜的容后說明。
            事實(shí)上,我不鼓勵使用觸發(fā)器。觸發(fā)器的初始設(shè)計(jì)思想,已經(jīng)被“級聯(lián)”所替代.
            posted on 2008-04-18 16:09 學(xué)習(xí)才能進(jìn)步 閱讀(192) 評論(0)  編輯 收藏 引用 所屬分類: SQL
            久久青青草原精品国产软件| 久久91综合国产91久久精品| 四虎国产精品成人免费久久| 亚洲国产成人久久精品99| 麻豆国内精品久久久久久| 中文字幕乱码人妻无码久久| 国产精品久久自在自线观看| 久久精品国产WWW456C0M| 国产精品乱码久久久久久软件| 国产成人精品久久| 成人午夜精品久久久久久久小说| 久久www免费人成精品香蕉| 久久久亚洲欧洲日产国码是AV| 97久久超碰国产精品2021| 伊人色综合久久天天人守人婷 | 久久99精品国产麻豆| 久久精品一区二区影院| 久久久久99精品成人片欧美| 久久久久国产精品麻豆AR影院 | 久久精品www人人爽人人| 久久天天躁狠狠躁夜夜av浪潮| 99国产欧美精品久久久蜜芽| 久久精品人人做人人爽电影| 亚洲а∨天堂久久精品| 人人狠狠综合久久亚洲婷婷| 久久久久亚洲AV无码网站| 亚洲综合久久久| 天天影视色香欲综合久久| 色偷偷888欧美精品久久久| 久久精品国产网红主播| 人人狠狠综合久久88成人| 久久天天躁狠狠躁夜夜不卡| 亚洲国产一成久久精品国产成人综合 | 99久久精品久久久久久清纯| 久久天天躁狠狠躁夜夜网站| 国内高清久久久久久| 久久久久久久免费视频| 欧美日韩久久中文字幕| 合区精品久久久中文字幕一区| 久久久久亚洲AV成人网人人软件 | 老男人久久青草av高清|