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