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

SQLServer分布式查詢(xún)

  MSSQlServer所謂的分布式查詢(xún)(Distributed Query)是能夠訪問(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ù)器訪問(wèn). 而這些查詢(xún)是否被使用完全看使用的需要.

  本篇將演示利用SQlExpress鏈接遠(yuǎn)程SQlServer來(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]上訪問(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è)诰彺?a href=/yuedu/fuwuqi/ target=_blank class=infotextkey>服務(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ù)訪問(wèn)的API是OLE_DB, 而對(duì)數(shù)據(jù)庫(kù)MSSQlServer 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 訪問(wèn)接口訪問(wèn)的關(guān)系和非關(guān)系數(shù)據(jù)源中的異類(lèi)數(shù)據(jù)

  OLE DB 訪問(wèn)接口將在稱(chēng)為行集的表格格式對(duì)象中公開(kāi)數(shù)據(jù)。SQL Server 允許在 Transact-SQL 語(yǔ)句中像引用 SQL Server 表一樣引用 OLE DB 訪問(wèn)接口中的行集,[其實(shí)不用關(guān)心這個(gè)行集概念 它的功能類(lèi)似SQl中臨時(shí)表 不過(guò)它容積更大 能容納類(lèi)型更多 更豐富]

  SQL Server 實(shí)例的客戶(hù)機(jī)與 OLE DB 訪問(wèn)接口之間的連接 如下圖:

  從上圖可以看出.客戶(hù)端借助OLEDB接口可以訪問(wèn)Oracle/MS Jet/MS SQL/ODBC/第三方等這些豐富數(shù)據(jù)源來(lái)我們分布式查詢(xún)提供數(shù)據(jù). 說(shuō)了這么多關(guān)于OLEDB底層支持. 關(guān)于在MSSQL2005中則支持兩種方式來(lái)進(jìn)行分布式查詢(xún):

  <A>使用添加鏈接服務(wù)器方式(Add Link Server)

  <B>使用特定名稱(chēng)及特定數(shù)據(jù)源來(lái)直接指定(Add Host Names)

  其實(shí)這兩種方式在實(shí)際運(yùn)用中是有區(qū)別的:

  方式A:Add Link Server方式建立服務(wù)器之間關(guān)聯(lián).創(chuàng)建一個(gè)鏈接的服務(wù)器,使其允許對(duì)分布式的、針對(duì) OLE DB 數(shù)據(jù)源的異類(lèi)查詢(xún)進(jìn)行訪問(wèn). 一般適用于持久的數(shù)據(jù)操作 對(duì)于數(shù)據(jù)量偏大 服務(wù)器之間交付時(shí)間長(zhǎng)特點(diǎn).

  方式B: Add Host Name 利用域來(lái)唯一識(shí)別數(shù)據(jù)庫(kù)以及數(shù)據(jù)庫(kù)表對(duì)象. 來(lái)實(shí)現(xiàn)跨服務(wù)器訪問(wèn). 這種方式一般比較簡(jiǎn)單 主要適用于對(duì)數(shù)據(jù)需求臨時(shí)性查詢(xún)是使用偏多. 不適合做大批量數(shù)據(jù)提取. 有性能瓶頸.

  <2>分布式查詢(xún)實(shí)現(xiàn)

  在進(jìn)行實(shí)現(xiàn)分布式查詢(xún)之前.本次測(cè)試Demo對(duì)應(yīng)的SQL版本:

  確定SQLServer版本后如下會(huì)演示兩種方式來(lái)實(shí)現(xiàn)分布式查詢(xún),并對(duì)Distributed Query中詳細(xì)細(xì)節(jié)進(jìn)行說(shuō)明.

  <2.1>鏈接服務(wù)器查詢(xún)

  鏈接服務(wù)器配置使 SQL Server 可以對(duì)遠(yuǎn)程服務(wù)器上的 OLE DB 數(shù)據(jù)源執(zhí)行命令。鏈接服務(wù)器具有以下優(yōu)點(diǎn):

  1. 訪問(wèn)遠(yuǎn)程服務(wù)器
  2. 能夠?qū)ζ髽I(yè)內(nèi)的異類(lèi)數(shù)據(jù)源發(fā)出分布式查詢(xún)、更新、命令和事務(wù)。
  3. 能夠以相似的方式確定不同的數(shù)據(jù)源

  下圖顯示了鏈接服務(wù)器配置的基礎(chǔ):

  現(xiàn)在利用鏈接服務(wù)器方式實(shí)現(xiàn)數(shù)據(jù)訪問(wèn)遠(yuǎn)程服務(wù)器數(shù)據(jù)庫(kù)CustomerDB中Users表數(shù)據(jù)先本地添加LinkServer:

   1:  -- 建立連接服務(wù)器  第一步建立連接  IP方式來(lái)控制 
2:
3: EXEC sp_addlinkedserver '192.168.10.104' , 'SQL Server'
4:
5: -- 查看鏈接服務(wù)器信息 [測(cè)試連接成功]
6:
7: select name , product, provider, data_source, query_timeout, lazy_schema_validation, is_remote_login_enabled, is_rpc_out_enabled
8: from sys.servers
9: where is_linked= 1

  <3>問(wèn)題排查與更多查詢(xún)方式

  當(dāng)我們?cè)趯?shí)際編程中進(jìn)行訪問(wèn)遠(yuǎn)程數(shù)據(jù)時(shí) 因?yàn)椴煌僮鳝h(huán)境會(huì)引發(fā)各種各樣的異常,如下我會(huì)提出一種常見(jiàn)的異常方式解決辦法和關(guān)于遠(yuǎn)程數(shù)據(jù)操作更多查詢(xún)方式.

  <3.1>無(wú)法建立遠(yuǎn)程連接

  其實(shí)這個(gè)問(wèn)題在做分布式查詢(xún)時(shí)極其常見(jiàn). 而引起這個(gè)問(wèn)題的因素過(guò)多. 我們一時(shí)無(wú)法判斷真正引發(fā)這個(gè)異常地方. 只能通過(guò)逐個(gè)排查方式來(lái)進(jìn)行設(shè)置:

  例如我們?cè)诮㈥P(guān)聯(lián)關(guān)系后 進(jìn)行查詢(xún)時(shí)會(huì)遇到:

  提示是: 在進(jìn)行遠(yuǎn)程連接時(shí)超時(shí), 引起這個(gè)問(wèn)題原因可能是遠(yuǎn)程服務(wù)器積極拒絕訪問(wèn)!

  首先要在Sql Server Configuation Manager中保證你服務(wù)已經(jīng)運(yùn)行 且是開(kāi)機(jī)自動(dòng)運(yùn)行.

  再次檢查SQl2005外圍配置DataBaseEngine允許遠(yuǎn)程連接:

  設(shè)置完成后.我們還需要設(shè)置Sql Server Analysis Services分析服務(wù)也支持遠(yuǎn)程數(shù)據(jù)查詢(xún):

  在遠(yuǎn)程服務(wù)器上如果啟用了防火墻則可能對(duì)目前SQl Server方位實(shí)例進(jìn)行攔截. 所以在服務(wù)器端啟用防火墻情況下要為SQl DAtaBase創(chuàng)建例外.防止客戶(hù)端請(qǐng)求被攔截.

  <3.2>進(jìn)程被其他用戶(hù)占用

  當(dāng)我們?cè)谶h(yuǎn)程分布式查詢(xún)中有創(chuàng)建動(dòng)作或是類(lèi)似創(chuàng)建一個(gè)新的數(shù)據(jù)庫(kù). 有時(shí)會(huì)提示 “該數(shù)據(jù)庫(kù)無(wú)法操作 已經(jīng)別其他進(jìn)程占用”異常. 導(dǎo)致我們無(wú)法訪問(wèn)數(shù)據(jù)庫(kù). 或是執(zhí)行我們要做的創(chuàng)建操作.

  遇到這種情況我們可以利用SA權(quán)限查詢(xún)到Master數(shù)據(jù)庫(kù)對(duì)應(yīng)數(shù)據(jù)庫(kù)被占用的進(jìn)程 并殺掉Kill Process.查詢(xún):

   1:  -- [sysprocesses 表中保存關(guān)于運(yùn)行在 Microsoft® SQL Server™ 上的進(jìn)程的信息。
2: -- 這些進(jìn)程可以是客戶(hù)端進(jìn)程或系統(tǒng)進(jìn)程。sysprocesses 只存儲(chǔ)在 master 數(shù)據(jù)庫(kù)中]
4: use Master
5: go
7: SELECT * FROM sysprocesses ,sysdatabases WHERE sysprocesses.dbid=sysdatabases.dbid AND sysdatabases.Name='CustomerDB'
9: select * from sysprocesses
11: select * from sysdatabases
13: -- 殺死占用進(jìn)程
14: kill 5

it知識(shí)庫(kù)SQLServer分布式查詢(xún),轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 把腿张开老子CAO烂你动态图 | np高h肉辣一女多男 no视频在线观看 | 娇喘嗯嗯 轻点啊视频福利 娇喘高潮教室h | AV福利无码亚洲网站麻豆 | 亚欧免费观看在线观看更新 | 姐姐不~不可以动漫在线观看 | 97视频在线观看视频最新 | 四虎影院2022 | 多人乱肉高hnp | 偷拍亚洲制服另类无码专区 | 快插我我好湿啊公交车上做 | FREECHINESE东北女人真爽 free18sex性自拍裸舞 | 国内精品乱码卡一卡2卡三卡新区 | 香蕉97超级碰碰碰碰碰久 | 欧美精品久久久久性色AV苍井 | 恋夜影院安卓免费列表uc | 浪荡女天天不停挨CAO日常视 | 国产午夜精品鲁丝片 | 玖玖爱这里只有精品视频 | 亚洲视频在线免费观看 | 好满射太多了装不下了视频 | 潮 喷女王cytherea | 中文字幕无码亚洲字幕成A人蜜桃 | 国产九九九九九九九A片 | 99热这里只就有精品22 | 国精一区二区AV在线观看网站 | 激情办公室 | 4484在线观看视频 | 亚洲欧美精品一中文字幕 | 亚洲H成年动漫在线观看不卡 | 日本无码人妻精品一区二区视频 | 九九色精品国偷自产视频 | 久草在线新是免费视频 | 公和熄洗澡三级中文字幕 | 色欲蜜臀AV免费视频 | 毛片手机在线观看 | 中国农村妇女真实BBWBBWBBW | 国产日韩精品一区二区在线观看 | AV色蜜桃一区二区三区 | 99久久人妻无码精品系列性欧美 | 亚洲午夜久久久精品影院 |