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