[SQL Server]Trigger的簡單範例,以「訂單的流程系統」為例

摘要:[SQL Server]Trigger的簡單範例,以「流程系統」為例

故意修改第一個訂單資料表的「狀態」
我們發現:Log資料表會立即記錄他的更動狀況

 

 

====上課用的補充範例====

 

有很多情況不是自己用ASP.NET的程式來硬幹 (Hard Coding)

資料庫可以幫上忙

 

舉例來說,有一個流程系統(TEST資料表)

同一筆記錄,從初始的狀態A,會一路變化 B...C....D....以此類推,最後到Z

(例如:(A).訂單進來了,(B).要檢查訂單內容?(C).是否有貨?(D).庫房人員要撿貨?(E).包裝?(F).快遞來收貨....    這就是一連串的 "流程",

      ........  最後,(X).客戶收到貨品,(Y).我們收到款項,(Z).最後寄出發票  才結案!) 

 

如果使用新增 (Insert Into) 的方法來做,同一筆工作單 就會在 TEST資料表裡面,保留 A~Z,總共 26個狀態

資料量大的時候,

日後查找就麻煩,速度也會變慢

 

如果每一次修改(Update)「狀態」的時候,

只做 Update的指令、只修改狀態碼

 

把 "上一個狀態"寫入另外一個 TEST_Log資料表(日後待查,有這筆工作單完整流程與經手人) 

這樣既簡單、解了上面問題,也滿足客戶想查歷史流程的要求

 

三個資料表的職責:

TEST,仍在作業中、未結案的資料表。

TEST_Log,工作單 "各種狀態"的完整記錄。

TEST_Histroy,確定結案的工作單。

 

以圖片來解說流程:

 

第一,當我在訂單資料庫裡面,加入「訂單」。預設的狀態都是A。

      

 

第二,不管是新增訂單?或是修改原有訂單(狀態值)?

       都會即刻「備份」到 Log資料表裡面。

      

 

第三,故意修改第一個訂單資料表的「狀態」

         我們發現:Log資料表會立即記錄他的更動狀況

      

 

第四,我故意把一筆訂單的狀態,改成 Z(已結案)

      這時候,LOG資料表仍會記錄他的狀態喔~

      結案之後,這筆訂單會從第一個資料表刪除!搬移到 History資料庫(已結案)備查

      

 

*****************************************************************************************

上面的流程,您想怎麼做?

      把 "SQL指令" 寫在 "ASP.NET網頁" 裡面嗎?

      還是...... 透過 資料庫的 Trigger來幫忙 ?

*****************************************************************************************

 

簡單的 Trigger寫法如下:

CREATE TRIGGER [幫你的Trigger取一個名字001]
   ON  [dbo].[TEST]
   For UPDATE,INSERT    '--註解:只有要更新(update)、新增(insert)的動作,都會觸發這段流程
AS
 
IF (UPDATE(狀態欄位))     '-- 如果狀態欄位 有人去更動......例如:從A變成B、從B變成C等等
BEGIN
    SET NOCOUNT ON
 
    Insert Into TEST_Log Select * From Inserted
     '-- 狀態一旦有更新,就把上一個「狀態值」,寫入 Log資料表(日後備查)
 
END

 

結果請看上圖(一、二、三)

=======================================================================================

 

如果這筆工作單,流程已經跑完了(結案!到達狀態Z)

就不需要存放在 TEST資料表,TEST資料表只保留「正在運作中」、「未結案」的工作單)

 

把這筆「確定完成(結案)」的工作單轉移到 History資料表,然後從 TEST資料表刪除(節省空間)

CREATE TRIGGER [幫你的Trigger取一個名字002]
   ON  [dbo].[TEST]
   AFTER Update
AS
IF (UPDATE(欄位名稱))
BEGIN
    DECLARE @TEST_id int
    SET NOCOUNT ON
 
    Select @TEST_id=TEST_id From Inserted Where 狀態欄位 = 'Z'    '--流程已經結束
 
    IF @TEST_id is NOT NULL    '-- 找到狀態是Z的工作單,表示這筆流程已經結束。便放入 History資料表
      BEGIN
           Insert Into TEST_History Select * From Inserted Where TEST_id = @TEST_id
 
           Delete From TEST Where TEST_id = @TEST_id  
           '--流程已經結束,這筆工作單可以刪除。    可以去 History資料表查詢(已結案的工作單)
      END
 
END

結果請看上圖四

 

 

我從手邊範例去修改簡化,可能有些小錯

但流程大概是這樣

 

=======================================================================================

看完這幾篇,自己練習一下就會了

其實很簡單(當然,我是買書來看的,比較有系統。有T-SQL指令的書都會講)

 
 
 
微軟官方文件:  正體中文。   CREATE TRIGGER (Transact-SQL)

=======================================================================================

 

 

常常有初學者問到的問題:

      我每新增一筆訂單,我希望存入「資料庫A」與「資料庫B」

      因為資料庫B是我的備份DB......

 

如果您用ADO.NET來寫,當然也行(但不建議)

但資料庫本身就有這樣的功能,您可以做 Mirror  (資料庫鏡像,未來的新版本將會移除此功能。建議改用:SQL Server 2012以後稱為 Always-On)

http://msdn.microsoft.com/zh-tw/library/ms189852.aspx

 

不需要在程式裡面 Hard Coding,太辛苦了。

資料庫轉移、批次備份,這些應該都是資料庫的事情。不是寫(畫面)程式的人去做的。

      這不就是MVC的觀念?

      你寫畫面(Viewer)的ASP.NET程式,卻用它(ASP.NET程式)去管資料模組(Model / DB)定期備份的工作?  搞的一團亂

      沒有因材施教、沒有專才專用?.....活該,累死你~

 

 

常見問題:

我要寫一個網頁程式,每天晚上十二點,執行SQL指令做資料庫完整備份。

 

拜託!這是資料庫的事,不能請資料庫定時去做嗎?(買SQL Server的書來看一下吧)

你真的要定時「喚醒」這個網頁程式(我還真的不會做),再叫資料庫起床工作?

 

醒醒吧!因為你只會寫網頁,不懂資料庫才會這樣搞,這就是不分青紅皂白、 Hard Coding

 

 

我 100%相信,有人可以用一套軟體,例如 Word

把所有工作都完成,還能繪圖、編輯圖片呢

 

但我會用 Word(文字) / PhotoShop(圖片) 各自20%的簡單功能

搞不好組合起來,成果也不輸給你

 

如果你在 ASP.NET入門的課程,希望能教到 SQL Server的 Stored Procedure ? Trigger ?  View? 怎麼寫?怎麼用?

我覺得這根本離題了。

 

上課時間就是固定的,ASP.NET Web Form東西這麼多都講不完,你還想要「附帶」把SQL Server學一遍

包山包海,結果就是什麼都不精

 

不要想來「吃到飽」

這是一個講究專業的時代

 

如果您真的對SQL Server有興趣,應該好好深入了解這個「商業程式 與 商業邏輯 的 核心」!

需要更專業的課程

不是在 ASP.NET(入門)課程裡面「順便」找答案

 

老祖宗的名言:不要貪小便宜,免費的最貴!

 

 

 

 

 

我將思想傳授他人, 他人之所得,亦無損於我之所有;

猶如一人以我的燭火點燭,光亮與他同在,我卻不因此身處黑暗。----Thomas Jefferson

線上課程,遠距教學 (Web Form 49hr)  https://dotblogs.com.tw/mis2000lab/2016/02/01/aspnet_online_learning_distance_education_VS2015

線上課程,遠距教學 (ASP.NET MVC 75~80hr)  https://dotblogs.com.tw/mis2000lab/2018/08/14/ASPnet_MVC_Online_Learning_MIS2000Lab

ASP.NET MVC線上課程 第一天 免費看 (5.5小時) 

寫信給我,不要私訊 --  mis2000lab (at) yahoo.com.台灣  或  school (at) mis2000lab.net


ASP.NET遠距教學、線上課程(Web Form + MVC)。 第一天課程, "完整" 試聽。 

................   facebook社團   https://www.facebook.com/mis2000lab   ......................

................  YouTube (ASP.NET) 線上教學影片  https://www.youtube.com/channel/UC6IPPf6tvsNG8zX3u1LddvA/

 

Blog文章 "附的範例" 無法下載,請看 這裡 ...... https://dotblogs.com.tw/mis2000lab/2016/03/14/2008_2015_mis2000lab_sample_download

請看我們的「售後服務」範圍(嚴格認定)

...................................................................................................................................................... 

[遠距教學、教學影片] ASP.NET (Web Form) 課程 上線了!MIS2000Lab.主講

事先錄製好的影片,並非上課時側錄!   觀看影片時,有如我「一對一」跟您面對面講課

 

ASP.NET MVC 5 線上教學

         累積時數約 75~ 80小時...... 第一天(5.5小時)完整內容,"免費"讓您評估