天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

追蹤記錄每筆業務操作數據改變的利器——SQLCDC

  對于大部分企業應用來用,有一個基本的功能必不可少,那就是Audit Trail或者Audit Log,中文翻譯為追蹤檢查、審核檢查或者審核記錄。我們采用Audit Trail記錄每一筆業務操作的基本信息,比如操作的基本描述、操作時間、操作者等。對于一些安全級別比較高的應用,或者操作一些比較敏感的數據,我們甚至需要記錄該筆業務操作引起的數據的改變。具體來說,這里的“數據改變”指的是每一條影響的記錄在操作執行前后的變化。對于添加的記錄,需要記錄下新插入的記錄;對于刪除的記錄,需要記錄下原來的記錄;對于更新的記錄,則需要同時記錄下更新前后的記錄。

  說到這里,很多人都會想到采用觸發器的方式來實現對數據改變的捕捉。但是這種實現方案具有一個最大的局限:由于觸發器是在數據操作所在事務范圍內執行的,所有會帶來性能的問題,嚴重的話還會因為觸發器的執行導致事務超市。所以在這里,我們介紹一種更好的解決方案:SQLCDC。

目錄
一、SQLCDC簡介
二、在數據庫級別開啟CDC
三、為某個數據表開啟CDC
四、記錄添加記錄的數據改變
五、記錄刪除數據的數據改變
六、記錄更新記錄的數據改變

  一、SQLCDC簡介

  CDC的全名為Change Data Capture,顧名思義,就是用于追蹤和捕捉數據改變。CDC是在SQL Server 2008中才出現的新特性,而這個特性則在很早之前就出現在了Oracle中。對于SQL Server之前版本來說,在沒有CDC的情況下,如果需要記錄基于某個數據表的數據改變,我們只能采用觸發器,具體來說就是通過手工創建After Insert、After Update和After Delete觸發器去記錄變化的數據。而CDC給了我們一種更為方便、易用和省心的方式去記錄某個數據表的歷史操作。

  二、在數據庫級別開啟CDC

  在默認的情況下,數據庫的CDC特性是被關閉的,你可以通過系統表sys.databases的is_cdc_enabled字段確定某個數據庫的CDC是否開啟。如果在默認的情況下,我執行如下的SQL語句查看數據庫TestDb的CDC是否開啟,你將會看到該字段的值為0。

  你可以通過執行系統存儲過程sys.sp_cdc_enable_db為當前數據庫開啟CDC特性。下面的T-SQL代碼片斷中,我們通過執行該存儲過程為TestDb打開了CDC特性。

Use TestDb
Go
Exec sys.sp_cdc_enable_db
Go

it知識庫追蹤記錄每筆業務操作數據改變的利器——SQLCDC,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 97午夜理论片影院在线播放 | 三级黄色一级视频 | 辣文肉高h粗暴 | 国产成人片视频一区二区青青 | 亚洲欧美精品一中文字幕 | 亚洲综合AV在线在线播放 | 久久亚洲伊人中字综合精品 | 国产看午夜精品理论片 | 69精品人人人人 | 护士美女照片 | 国产精品久久久久秋霞影视 | 国产综合18久久久久久软件 | 九九热精品视频在线观看 | 欧美人成在线观看ccc36 | 上课失禁丨vk | 午夜福利网国产A | 亚洲免费人成 久久 | 亚洲区偷拍自拍29P 亚洲区视频在线观看 | 国产亚洲日韩在线播放不卡 | 国产在线亚洲v天堂a | 日本老师xxxxx18 | 紧缚束缚调教丨vk | 国产精品人妻99一区二 | thermo脱色摇床安卓下载 | 蜜桃视频一区二区 | 四虎国产精品永久免费入口 | 国产欧美一本道无码 | 高跟丝袜岳第一次 | 日韩精品卡1卡2三卡四卡乱码 | 精品国产福利一区二区在线 | 97一期涩涩97片久久久久久久 | 久久青草免费91线频观看站街 | 伊人亚洲综合网色 | 丰满少妇69激懒啪啪无码 | 人妻天天爽夜夜爽三区麻豆A片 | 日韩毛片大全 | 被男按摩师添的好爽在线直播 | 亚洲精品婷婷无码成人A片在线 | 国产成人综合95精品视频免费 | 久久99国产精品二区不卡 | 女人被躁到高潮嗷嗷叫69 |