標籤:style blog http color 使用 io strong 資料
在酒店管理系統開發中,我們會建立房間表和房間類型表(房型表)這兩個表,如所示:
房型表:RoomType
房間表:Room
首先這兩個表的關係:Room是從表,RoomType是主表,兩表有主外鍵關係,RoomType.rTypeId=Room.rTypeId
分析這兩個表,我們會發現這樣一個問題:在房間表和房型表管理中,當我們修改或者刪除一個RoomType表,對應的Room表我們也要做修改和刪除,那麼我們怎麼解決這個問題呢?首先可以在資料庫中設定串聯刪除,或者利用觸發器也可以解決、、、這些方法都有一定的弊端,在實際開發中,我們會採取使用事務來解決這個問題,這種方法簡單而且開發效率高,容易維護。
要求:在刪除RoomType的同時把Room表中存在該房型的也刪除.
思路:在刪除RooType的時候,我們通過RoomType.rTypeId=Room.rTypeId找到Room中存在該房型的記錄,把也它刪掉。
說明:刪除不是把整條記錄從資料庫刪除,是將資料標識改為1,0是代表未刪除。
下面介紹刪除的預存程序:
代碼:
1 ALTER procedure [dbo].[usp_DelToomType] --建立刪除房型的預存程序 2 @rTypeId int --房型參數 3 as 4 begin transaction --開始事務 5 declare @error int --定義一個變數標識錯誤號碼 6 update RoomType set rTypeIsDel=1 where [email protected] --根據條件刪除房型,rTypeIsDel=1標識刪除,0標識未刪除 7 set @error+=@@ERROR 8 if(@error<>0) --不等於0說明這一句執行出現錯誤 9 rollback transaction --交易回復10 update Room set roomIsDel=1 where [email protected] --根據條件刪除房間11 set @error+=@@ERROR 12 if(@error<>0) --不等於0說明這一句執行出現錯誤13 rollback transaction --交易回復14 else 15 commit transaction --提交事務
最後,資料層直接調用預存程序的方法即可完成刪除房型的同時把存在該房型的房間也刪除。