SQL Server Replication 中關於視圖的點滴

来源:http://www.cnblogs.com/kerrycode/archive/2016/03/19/5294723.html
-Advertisement-
Play Games

在伺服器A資料庫TEST新建了一個本地發佈(Local Publications)RPL_GES_MIS_TEST,在伺服器B資料庫RPL_TEST上創建了一個本地訂閱(Local Subscriptions),它訂閱了了這個發佈RPL_GES_MIS_TEST.如下截圖所示,本地發佈只有DB_OB...


    在伺服器A資料庫TEST新建了一個本地發佈(Local Publications)RPL_GES_MIS_TEST,在伺服器B資料庫RPL_TEST上創建了一個本地訂閱(Local Subscriptions),它訂閱了了這個發佈RPL_GES_MIS_TEST.如下截圖所示,本地發佈只有DB_OBJECTS 、Location兩個表

clipboard

假設現在有一個需求,我們需要同步一個視圖V_DB_OBJECTS(當然實際情況應該比這個複雜,有可能視圖是多個表關聯,測試場景我們先簡化一下),視圖代碼如下

CREATE VIEW V_DB_OBJECTS
AS
 SELECT * FROM DB_OBJECTS WHERE type !='S';

我們右鍵單擊RPL_GES_MIS_TEST的屬性,在Articles裡面添加了該視圖

clipboard[1]

此時我們使用sp_helpsubscription查看訂閱的特定的發佈、項目、訂閱伺服器或訂閱集關聯的訂閱信息。就會發現視圖V_DB_OJBECTS的subscription status為1,表示訂閱伺服器正在請求數據,但尚未同步。

clipboard[2]

此時你右鍵單擊對應的本地發佈RPL_GES_MIS_TEST,選擇“View Snapshopt Agent Status",如下所示,你會看到它提示快照生成了2個項目,意味著其實這個視圖不在快照裡面。

clipboard[3]

clipboard[4]

此時,你點擊開始,重新生成快照,你會發現下麵信息。快照重新初始化了3個項目。

clipboard[5]

那麼我們有沒有辦法,在發佈訂閱裡面,只同步一個新的視圖,而不用初始化整個快照嗎? 答案是有,其實方法很簡單,具體可以參考我這篇文章SQL SERVER Transactional Replication中添加新表如何不初始化整個快照 。此處不做展開分析

CREATE VIEW V_DB_OBJECTS_2
AS
 SELECT * FROM DB_OBJECTS WHERE type !='S'
 
 
 
USE TEST;
GO
 
EXEC sp_changepublication
@publication = 'RPL_GES_MIS_TEST',
@property = 'allow_anonymous' ,
@value = 'false'
GO
EXEC sp_changepublication
@publication = 'RPL_GES_MIS_TEST',
@property = 'immediate_sync' ,
@value = 'false'
GO 

執行上面腳本後,我們在發佈裡面的項目(Articles)裡面添加視圖V_DB_OBJECTS_2,然後我們在View Snapshot Agent Status視窗,單擊“Start"按鈕,你會發現快照只生成了這個視圖。如下所示

clipboard[6]

另外,可能有同學有疑問,如果我的視圖已經通過Replication同步了,那麼我修改視圖有沒有影響?會不會也同步過去呢? 如下所示,修改V_DB_OBJECTS_2

clipboard[7]

你會發現修改過後的視圖很快就同步到訂閱服務的資料庫上,但是要註意,如果選項”Replicate schema changes"為False,那麼此時對視圖的修改是不會同步過去

clipboard[8]

另外需要註意:對視圖的修改僅僅限制在視圖的引用對象也在複製(Replication)當中,如果引用了一個不在複製(Replication)的項目,那麼此時就會有問題了。其實不光是修改已經同步的視圖,其實同步一張新的視圖,如果視圖引用的項目(對象)不在發佈訂閱(Replication)當中也會有問題,它會報如下錯誤:

Unable to replicate a view or function because the referenced objects or columns are not present on the Subscriber.

clipboard[9]

還有一種情況就是視圖所引用的對象都在發佈訂閱當中,但是視圖跨越了多個資料庫,那麼是否也有問題呢?

如下所示,視圖引用了TEST資料庫的表DB_OBJECTS和TTT資料庫的表mmFrameModel, 而且TTT資料庫的表mmFrameModel也同步到了訂閱資料庫RPL_DB_TEST當中,但是此時同步依然會有問題

CREATE VIEW V_TEST2
AS
 SELECT name  AS NAME  FROM DB_OBJECTS
 UNION ALL
 SELECT Machine_Model AS NAME FROM TTT.dbO.mmFrameModel;

有一個替換方案就是不同步視圖,而是在同步了視圖引用的對象後,在訂閱的資料庫上也創建同樣邏輯的視圖。只是這個替換方案有點麻煩的是,在修改了發佈資料庫上的視圖後,一定要記得也同時手動修改訂閱資料庫的視圖


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一個好的APP不僅有美觀,好看的界面,更需要良好的性能和穩定性。作為一名開發人員,需要理解界面設計原則並寫出優秀的界面設計代碼。 本章主要講述基本控制項的使用,界面佈局及一些常用的界面設計屬性。 (1) LinearLayout 相對佈局 android:android:layout_weight=”
  • 在之前我寫過SDWebImage的使用方法,主要是用與獲取網路圖片,沒有看過的朋友可以看看。 這篇文章將主要介紹SDWebImage的實現原理,主要針對於獲取網路圖片的原理,如果沒有第三方我們該怎麼去做,當然我知識用文字去介紹,我想花大把的時間去深入理解我們用不到的東西,是很不值得的,不過興趣的朋友
  • @@@描述 廣播接收器可以收到 Context.sendBroadcast或者Context.sendOrderedBroadcast發出的意圖(intent)。 @@@LocalBroadcastManager 如果你不需要誇應用發送廣播,建議你使用 LocalBroadcastManager, 
  • 本文主要實現通訊錄的部分功能(分組名、索引、分組的組名)等等功能: 廢話不多說了,先上效果圖: 在工程中需要導入一個plist文件,文件圖如圖: 工程目錄文件如圖: 工程程式如圖所示: RootTableViewController.h RootTableViewController.m 註: 通訊
  • 在一些下載應用里整個頁面都是按鈕,有好多好多,但是仔細觀察不難發現他們很有規律。就像下麵一樣👇 很有規律的排列在屏幕上,那麼這需要我們怎麼去做能。 正如標題,我們需要瞭解兩個知識點,分別是自定義按鈕和九宮格,九宮格是一種演算法。在這裡我給大家列出方法,並不過多解釋,希望會對大家有幫助。 代碼如下:
  • 原文地址 下載並打開xcode。 接著新建一個工程,如下圖所示: 點擊Create a new Xcode project,之後選擇ios下的Application,點擊Single View Application來創建我們的第一個項目。如圖所示: 創建完項目後,我們來編寫我們的第一個ios項目。
  • 它是什麼? 我每天讀一章。大約每天3小時,在索引,查詢處理那兩章花了8小時以上,在範式那節重新整理下以前的看法,非常不錯的書,翻譯的也不錯。相比國內的《資料庫系統概論》,這書適合自學,並且非常詳細,演算法偽代碼多。在索引一章,完全可以通過他的演算法加例子很好的理解索引的原理和應用,在查詢處理一節,對演算法
  • 今天用到的oracle資料庫,但是發現以前設置的密碼,忘記了,怎麼輸入都不對,所以從網上找了一下資料,解決了,然後整理分享給大家。 一、遇到的問題: 1.、忘記除SYS、SYSTEM用戶之外的用戶的登錄密碼。 2.、忘記SYS用戶,或者是SYSTEM用戶的密碼。 3.、如果SYS,SYSTEM用戶的
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...