SQL Server所謂的分布式查詢(Distributed Query)是能夠訪問存放在同一部計算機或不同計算機上的SQL Server或不同種類的數據源, 從概念上來說分布式查詢與普通查詢區別 它需要連接多個MSSQL服務器也就是具有多了數據源。實現在服務器跨域或跨服務器訪問。 而這些查詢是否被使用完全看使用的需要。
本篇將演示利用SQL ServerExpress鏈接遠程SQL Server來獲取數據方式來詳細說明分布式查詢需要注意細節。先看一下系統架構數據查詢基本處理:
當然如果采用了分布式查詢 我們系統采取數據DataBase也就可能在多個遠程[Remote Server]上訪問時:
如上截取系統架構中關于數據與緩存流向中涉及的分布式查詢業務, 當我們從客戶端Client發起請求數據時。 首先檢查MemCache Server緩存服務器是否有我們想要數據。 如果沒有我需要查詢數據庫。 而此時數據要求查詢多個遠程服務器上多個數據庫中表, 這時利用分布式查詢。獲得數據 然后更新我們在緩存服務器MemCache Server上數據保持數據更新同步, 同時向客戶端Client直接返回數據。那如何來執行這一系列動作中最為關鍵分布式查詢?
《1》分布式查詢方式
我們知道Microsoft微軟公用的數據訪問的API是OLE_DB, 而對數據庫MSSQL Server 2005的分布式查詢支持也是OLE_DB方式.SQL Server 用戶可以使用分布式查詢訪問以下內容:
A:存儲在多個 SQL Server 實例中的分布式數據
B:存儲在各種可以使用 OLE DB 訪問接口訪問的關系和非關系數據源中的異類數據
OLE DB 訪問接口將在稱為行集的表格格式對象中公開數據。SQL Server 允許在 Transact-SQL 語句中像引用 SQL Server 表一樣引用
OLE DB 訪問接口中的行集,[其實不用關心這個行集概念 它的功能類似SQL Server中臨時表 不過它容積更大 能容納類型更多 更豐富]
更多信息請查看IT技術專欄