国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

詳解SQL Server分布式查詢

數據庫 SQL Server 分布式
在這里我們將要討論的是微軟SQL Server分布式查詢的實現,包括遠程鏈接數據庫等詳細的操作。

SQL Server所謂的分布式查詢(Distributed Query)是能夠訪問存放在同一部計算機或不同計算機上的SQL Server或不同種類的數據源, 從概念上來說分布式查詢與普通查詢區別 它需要連接多個MSSQL服務器也就是具有多了數據源.實現在服務器跨域或跨服務器訪問. 而這些查詢是否被使用完全看使用的需要.

本篇將演示利用SQL ServerExpress鏈接遠程SQL Server來獲取數據方式來詳細說明分布式查詢需要注意細節.先看一下系統架構數據查詢基本處理:

 memcached

當然如果采用了分布式查詢 我們系統采取數據DataBase也就可能在多個遠程[Remote Server]上訪問時: 

 2010-09-08_181001

如上截取系統架構中關于數據與緩存流向中涉及的分布式查詢業務, 當我們從客戶端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中臨時表 不過它容積更大 能容納類型更多 更豐富]

SQL Server 實例的客戶機與 OLE DB 訪問接口之間的連接 如下圖:

 2010-09-08_182420

從上圖可以看出.客戶端借助OLEDB接口可以訪問Oracle/MS Jet/MS SQL/ODBC/第三方等這些豐富數據源來我們分布式查詢提供數據. 說了這么多關于OLEDB底層支持. 關于在MS SQL 2005中則支持兩種方式來進行分布式查詢:

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

<B>使用特定名稱及特定數據源來直接指定(Add Host Names)

其實這兩種方式在實際運用中是有區別的:

方式A:Add Link Server方式建立服務器之間關聯.創建一個鏈接的服務器,使其允許對分布式的、針對 OLE DB 數據源的異類查詢進行訪問. 一般適用于持久的數據操作 對于數據量偏大 服務器之間交付時間長特點.

方式B: Add Host Name 利用域來唯一識別數據庫以及數據庫表對象. 來實現跨服務器訪問. 這種方式一般比較簡單 主要適用于對數據需求臨時性查詢是使用偏多. 不適合做大批量數據提取. 有性能瓶頸.

#p#

<2>分布式查詢實現

在進行實現分布式查詢之前.本次測試Demo對應的SQL版本:

 2010-09-09_110812

確定SQL Server版本后如下會演示兩種方式來實現分布式查詢,并對Distributed Query中詳細細節進行說明.

<2.1>鏈接服務器查詢

鏈接服務器配置使 SQL Server 可以對遠程服務器上的 OLE DB 數據源執行命令。鏈接服務器具有以下優點:

  1. 訪問遠程服務器。
  2. 能夠對企業內的異類數據源發出分布式查詢、更新、命令和事務。
  3. 能夠以相似的方式確定不同的數據源

下圖顯示了鏈接服務器配置的基礎:

 IC99086

現在利用鏈接服務器方式實現數據訪問遠程服務器數據庫CustomerDB中Users表數據先本地添加LinkServer: 

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

如上市建立連接服務器最簡單方式.建立鏈接服務器過程其實調用了系統存儲過程Sp_addlinkedserver. 第一個參數為Name 其實用來唯一標識鏈接服務器. 當然可以其他任何有意義字符串來定義,但我個人建議使用遠程服務器的IP來標識.第二個參數是要添加為鏈接服務器的 OLE DB 數據源的產品名稱. 默認為Null,如果指定”SQL Server“則無需指定其他參數.

如果你的本地裝有多個數據庫實例. 第一個種方式就不適用.這是就需要用SQL Server2005架構來唯一標識:

  1. -- 含架構名  查詢數據兩種模式  
  2. select top 10 * from [192.168.10.104]. wl . 架構名 . 表名     
  3. -- 架構名 [采用默認架構名 ]    
  4. select top 10 * from [192.168.10.104]. CustomerDB . dbo. Users  

對于SQL Server 2005架構這個概念很多人比較陌生:

在用戶角色設置中需要對指定訪問數據CustomerDB具有讀寫權限:

 2010-09-09_131120

在遠程服務器創建TEst用戶時使用SQL Server身份驗證方式登錄 這時設置密碼為RemoteDB.在使用非Sa用戶進行遠程:

  1. -- 執行前先刪除已經存在數據    
  2. Exec sp_droplinkedsrvlogin [192.168.10.76],Null   
  3. Exec sp_dropserver 'demodb'    
  4. -- 創建服務器連接    
  5. EXEC  sp_addlinkedserver    
  6.  @server='demodb',-- 被訪問的服務器別名   
  7.         @srvproduct='',   
  8.       @provider='SQLOLEDB',   
  9. @datasrc='192.168.10.76'   -- 要訪問的服務器  
  10.   EXEC sp_addlinkedsrvlogin    
  11.   'demodb'-- 被訪問的服務器別名   
  12.     'false',   
  13.      NULL,     
  14.   'Test'-- 帳號    
  15.   'RemoteDB' -- 密碼 

如上我們首先清除已經可能創建服務器數據記錄. 然后創建服務器連接.sp_addlinkedSrvlogin系統存儲過程用來創建鏈接服務器上遠程登錄之間的映射 . 即我們可以詳細設置本地與遠程服務器詳細的映射信息. 例如設置我們特定用戶訪問的用戶名和密碼.

查詢數據

  1. -- 查詢指定用戶Test數據   
  2. select * from [demodb].CustomerDB.dbo.Users -- [如上測試成功] 

查詢結果

2010-09-09_120510  

指定用戶Test對CustomerDB訪問數據方式測試成功.

當測試完成后我們不需要這個連接服務器是即可利用SP_DroplinkServer刪除掉. 對應參數為創建時Name唯一標識. 通過Sp_helpserver來查看連接服務器詳細信息.

注意如上創建連接服務器時設置srvproduct參數即OLED數據源名稱時我們采用了SQlServer方式.

下面說明這種方式特點.:

這種方式是最為簡單直接的一種建立鏈接服務器方式. 但是存在前提的. 測試發現:

在所有數據庫的遠程連接 dbo 的方式必須建立在SA 密碼相同的基礎上 ,否則容易產生無法連接的情況 Sa用戶登錄失敗. 你也就明白這個SQlServer參數其實就是在本地數據拷貝服務器角色SysAdmin下用戶SA.來對服務器進行登錄. 如果你的本地Sa密碼與遠程服務器上密碼不一致 則無法正常連接.

經過測試還發現一種情況:

利用Windows7訪問XP(Sp2)系統時始終提示無法解析或拒絕連接SQL Server2005.這個問題我整了好久后來才到官方鏈接參數中發現.:如果你的XP系統沒有打上SP4的補丁包 這個問題會始終出現. 需要特別注意.

<2.2>直接指定數據源分布式查詢

其實相對第一種方式, 直接指定方式在SQL Server架構中 其實跳過本地與遠程服務器建立映射關系的這一步. 通過鏈接關系建立 其實就是建立一種內部映射關系. 如果沒有映射關系則 大部分設置需要手動控制.

直接指定數據源方式 需要開啟分布式查詢的基本權限 來進行查詢:

  1. -- 如果想使用分布式查詢,必須先開通分布式查詢 [外圍配置 這點是所有查詢操作前提]     
  2. -- sp_configure--顯示或更改當前服務器的全局配置設置    
  3. -- reconfigure 指定如果配置設置不需要服務器停止并重新啟動,則更新當前運行的值    
  4. -- SQL2005默認是沒有開啟’Ad Hoc Distributed Queries’ 組件     
  5. -- 啟用權限     
  6. exec sp_configure 'show advanced options',1  -- 顯示高級配置    
  7. reconfigure -- 更新值    
  8. exec sp_configure 'Ad Hoc Distributed Queries',1 -- 啟用分布式查詢    
  9. reconfigure   
  10. go    
  11.  -- 關閉分布式查詢   
  12. exec sp_configure 'Ad Hoc Distributed Queries',0       
  13. reconfigure    
  14. exec sp_configure 'show advanced options',0   
  15.  reconfigure   
  16.   go    
  17.   -- 開啟權限后 另外一種查詢方式   
  18. -- 查詢格式    
  19.  SELECT * FROM OPENDATASOURCE(    
  20.   'SQLOLEDB',    
  21.  'Data Source=遠程ip;User ID=sa;Password=密碼'    
  22.    ).庫名.dbo.表名   
  23.   WHERE 條件   
  24.   -- 需要開啟權限   
  25.  -- 開啟權限 提示[遠程的SqlServer不允許遠程連接]   
  26.   select * from OPENDATASOURCE('SQLOLEDB','Data Source=192.168.10.67; User ID=sa; Password=chenkai').wl.dbo.Users 

如上我們首先清除已經可能創建服務器數據記錄. 然后創建服務器連接.sp_addlinkedSrvlogin系統存儲過程用來創建鏈接服務器上遠程登錄之間的映射 . 即我們可以詳細設置本地與遠程服務器詳細的映射信息. 例如設置我們特定用戶訪問的用戶名和密碼.

查詢數據

  1. -- 查詢指定用戶Test數據     
  2. select * from [demodb].CustomerDB.dbo.Users -- [如上測試成功] 

查詢結果

 

2010-09-09_120510  

 

指定用戶Test對CustomerDB訪問數據方式測試成功.

#p#

<3>問題排查與更多查詢方式

當我們在實際編程中進行訪問遠程數據時 因為不同操作環境會引發各種各樣的異常,如下我會提出一種常見的異常方式解決辦法和關于遠程數據操作更多查詢方式.

<3.1>無法建立遠程連接

其實這個問題在做分布式查詢時極其常見. 而引起這個問題的因素過多. 我們一時無法判斷真正引發這個異常地方. 只能通過逐個排查方式來進行設置:

例如我們在建立關聯關系后 進行查詢時會遇到:

2010-09-09_133411

提示是: 在進行遠程連接時超時, 引起這個問題原因可能是遠程服務器積極拒絕訪問!

首先要在SQL Server Configuation Manager中保證你服務已經運行 且是開機自動運行.

再次檢查SQL Server 2005外圍配置DataBaseEngine允許遠程連接:

 2010-09-09_133756

設置完成后.我們還需要設置SQL Server Analysis Services分析服務也支持遠程數據查詢:

 2010-09-09_134058

在遠程服務器上如果啟用了防火墻則可能對目前SQL Server Server方位實例進行攔截. 所以在服務器端啟用防火墻情況下要為SQL Server DAtaBase創建例外.防止客戶端請求被攔截.

<3.2>進程被其他用戶占用

當我們在遠程分布式查詢中有創建動作或是類似創建一個新的數據庫. 有時會提示 “該數據庫無法操作 已經別其他進程占用”異常. 導致我們無法訪問數據庫. 或是執行我們要做的創建操作.

遇到這種情況我們可以利用SA權限查詢到Master數據庫對應數據庫被占用的進程 并殺掉Kill Process.查詢:

  1. -- [sysprocesses 表中保存關于運行在 Microsoft® SQL Server™ 上的進程的信息。     
  2. -- 這些進程可以是客戶端進程或系統進程。sysprocesses 只存儲在 master 數據庫中]   
  3. use Master    
  4. go    
  5. SELECT * FROM sysprocesses ,sysdatabases 
  6. WHERE sysprocesses.dbid=sysdatabases.dbid AND sysdatabases.Name='CustomerDB'    
  7.  select * from sysprocesses     
  8.  select * from sysdatabases   
  9. -- 殺死占用進程    
  10. kill 5 

當我們對進程占用清除時有可能訪問數據庫被系統進程占用. 則這時用Sa無法殺死.這時提示:

2010-09-09_134851

“Only use Process can be Kill ”在SQL Server2005 只有只有用戶進程才能Kill掉.

<3.3>更多的查詢操作

往往我們在實際操作中需要對數據讀寫有更多要求. 例如從遠程連接多個服務器進行數據讀取或是把本地數據提交到服務器上. 為了提高效率和性能采用分布式事務來進行批量操作等等. 如下簡單介紹在分布式查詢中多中數據操作:

把遠程數據導入本地:

  1. -- 導入數據操作   
  2. select top(3) * into TestDB.dbo.CopyDb from  [192.168.10.76].wl.dbo.Users 

導入時使用Into方式 自動在本地創建CopyDB表完全復制遠程服務器上Users表的數據結構.但是要注意在進行后 的CopyDB將不包含原表的主鍵和索引約束. 雖然能快構建 但是主鍵和索引設置都會丟失.

本地數據導入遠程:

  1. -- 把本地表導入遠程表 [openWset方式]  
  2.  insert openrowset( 'SQLOLEDB ''sql服務器名 ''用戶名 ''密碼 ',數據庫名.dbo.表名)  select *from 本地表   
  3. -- 把本地表導入遠程表 [open Query方式]  
  4.  insert openquery(ITSV, 'SELECT * FROM 數據庫.dbo.表名 ')   

更新本地表數據:

  1. -- 把本地表導入遠程表 [opendataSource方式]    
  2. insert opendatasource( 'SQLOLEDB ''Data Source=ip/ServerName;User ID=登陸名;Password=密碼 ').數據庫.dbo.表名      
  3. -- 更新本地表 [openowset方式]    
  4. update b  set b.列A=a.列A  from openrowset( 'SQLOLEDB ''sql服務器名 ''用戶名 ''密碼 ',數據庫名.dbo.表名)    
  5. as a inner join 本地表 b  on a.column1=b.column1   

當然還有更多方式來操作分布式查詢操作.各位都可以嘗試.

<4>尾 語

如上是我最近在項目中處理關于分布式查詢涉及到方方面面. 從系統架構到分部是查詢具體操作細節.基本都是一些非常基礎運用.當然也參考不少資料.以及動手來驗證整個過程出現問題原因所在. 篇幅有限 寫的有些倉促. 難免有紕漏地方 還望各位指正.

原文標題:MSSQl分布式查詢

鏈接:http://www.cnblogs.com/chenkai/archive/2010/09/09/1822305.html

【編輯推薦】

  1. SQL Server 2000刪除實戰演習
  2. SQL Server存儲過程的命名標準如何進行?
  3. 卸載SQL Server 2005組件的正確順序
  4. 對SQL Server字符串數據類型的具體描述
  5. SQL Server數據類型的種類與應用

 

責任編輯:彭凡 來源: 博客園
相關推薦

2010-07-06 09:39:20

SQL Server分

2022-03-29 23:17:52

PostgreSQL集群Citus

2019-10-10 09:16:34

Zookeeper架構分布式

2010-07-26 13:25:11

SQL Server分

2010-06-30 16:58:24

SQL Server分

2010-03-24 17:07:52

無線分布式系統

2024-08-12 16:20:27

2022-03-30 19:18:31

PostgreSQL分布式I/O

2009-09-18 15:10:13

分布式事務LINQ TO SQL

2010-07-05 15:48:44

SQL Server

2010-07-21 13:53:41

SQL Server分

2020-11-26 15:51:11

SQL數據庫大數據

2022-03-31 19:20:39

集群PostgreSQLCitus

2019-08-05 07:58:01

分布式架構系統

2010-07-23 13:25:31

2010-07-21 13:42:53

SQL Server分

2010-07-05 16:53:38

SQL Server

2010-08-27 09:48:14

無線分布式系統

2022-07-10 20:24:48

Seata分布式事務

2023-03-05 18:23:38

分布式ID節點
點贊
收藏

51CTO技術棧公眾號

久草福利视频在线| h片精品在线观看| 激情欧美丁香| 亚洲性线免费观看视频成熟| 在线免费看黄色| jlzzjlzz亚洲日本少妇| 97视频热人人精品| 精品国产一区二区三区性色av | 欧美日韩国产黄| 欧美久久久久久久久久久久久| 黄色精品免费| 日本一区二区不卡| 国产精品亚洲综合在线观看| 亚洲国产精品电影| 老司机免费在线视频| 婷婷夜色潮精品综合在线| 一道本在线免费视频| 高清成人免费视频| 一本一本a久久| 久久福利一区| dy888夜精品国产专区| 加勒比久久高清| 美日韩精品视频免费看| 少妇一区视频| 亚洲日韩欧美视频一区| 女囚岛在线观看| 欧美一区二区三区视频在线| 国产中文字幕在线播放| 欧美日韩美女在线观看| 一级毛片免费观看| 国产精品二区一区二区aⅴ污介绍| 国产成人无码精品久久久性色| 国产综合久久久久久鬼色| 狠狠色狠狠色综合人人| 伊人色**天天综合婷婷| 国产日韩欧美综合| 小处雏高清一区二区三区| 国产精品免费视频久久久| 欧美激情在线精品一区二区三区| 57pao成人国产永久免费| 欧美亚洲tv| 国产成人极品视频| 精品一区av| 91精品免费久久久久久久久| 欧美3p视频| 99超碰麻豆| 亚洲免费在线| 性欧美18一19内谢| 成人动漫视频在线| 高清av免费看| 午夜在线电影亚洲一区| h视频在线观看免费| 精品国产一二三| 国外成人福利视频| 97国产在线观看| 欧美午夜精品一区二区三区电影| 91久久精品久久国产性色也91| 欧美日韩第一区| 色大师av一区二区三区| 国产成人精品免费一区二区| 免费看的黄色大片| 国产精品污www在线观看| 另类图片激情| 色婷婷激情一区二区三区| a免费在线观看| 国产午夜精品全部视频播放| 亚洲精品一区二区三区在线| 国产成人av在线播放| 亚洲夜间福利| 在线观看污视频| 国产精品三级av| 国产美女视频一区二区三区| 亚洲精品久久久久久久久久久久久| 日韩在线免费| 97色在线视频观看| 一区视频在线看| 日本手机在线视频| 亚洲精品免费在线播放| 日本中文字幕在线视频| 在线观看视频亚洲| 精品国产一区二区三区噜噜噜 | 亚洲天堂男人天堂| 国产精品日本一区二区三区在线 | 韩国精品在线观看| 免费看a级黄色片| 欧美日韩在线第一页| 国产丝袜精品丝袜| 68精品久久久久久欧美| 在线视频亚洲| 亚洲成人av免费看| 在线综合视频播放| 欧美一区二区三区红桃小说| 欧美精品成人一区二区在线观看| jizz一区二区| fc2在线中文字幕| 欧美激情视频一区| 免费久久99精品国产自在现线| 成年人在线看片| 欧美精品v国产精品v日韩精品| 国产亚洲高清一区| 麻豆久久久av免费| 亚洲视频小说图片| 伊人成综合网站| 91精品在线一区| 久久久久久久久岛国免费| 青青影院在线观看| 91成人福利在线| 国产成人aaa| 久久精品视频观看| 国产精品人成电影在线观看| caoporm超碰国产精品| www.在线播放| 欧美在线视频一二三| 国产一区二区电影| 亚洲天天影视| 日韩av不卡在线| 成人av一区二区三区| 成人福利网址| 国产青草视频在线观看| 国产日韩在线播放| 一区二区三区资源| 久久精品久久99精品久久| 宅男午夜电影| 日本老师69xxx| 亚洲人av在线影院| 国产精品一二三四| 中文字幕一区二区三中文字幕| 啊灬啊灬啊灬啊灬高潮在线看| 亚洲人成毛片在线播放| 91久久午夜| 超碰在线电影| 欧美美最猛性xxxxxx| 男女啪啪免费观看| 日韩精品乱码免费| 中文在线三区| 国产福利91精品一区二区| 日本a在线播放| 国产精品成人一区二区| 热久久久久久久| 水莓100国产免费av在线播放| 久久97久久97精品免视看| 免费欧美在线视频| 欧美尤物美女在线| 91网免费观看| 午夜视频一区二区三区| 国产99久久| 电影天堂爱爱爱爱| 国模精品系列视频| 国产日韩影视精品| 老司机亚洲精品一区二区| 九一国产精品视频| 在线视频欧美性高潮| 国产精品亚洲人在线观看| 麻豆视频在线观看免费网站黄| 欧美精品国产精品久久久| 欧美卡1卡2卡| 精品1区2区3区4区| 国产午夜视频在线观看| 97人人澡人人爽| 色av一区二区| 欧美视频网站| 色老头视频在线观看| 免费成人看片网址| 欧美xxx久久| 国产一区二区三区在线观看免费视频| 欧美24videosex性欧美| 欧美aaa在线观看| 亚洲欧美国产精品| 成人精品免费网站| 亚洲欧美综合久久久久久v动漫| 日韩少妇内射免费播放| 欧美精品免费在线| 中文字幕一区二区三区不卡| 五月天亚洲色图| 在线视频三级| 91欧美激情另类亚洲| 一本一道久久a久久精品| 黑丝一区二区| 超碰在线网址| 污污污污污污www网站免费| 精品国产欧美一区二区五十路| 久久久综合激的五月天| 免费久久精品| 国产高清在线观看| 亚洲一区二区三区精品动漫| 在线观看不卡av| 国产日韩精品久久久| 欧美日韩在线网站| 91在线播放网站| 吴梦梦av在线| 久久久久久国产免费| 黄网站色欧美视频| 久久精品主播| 欧美一区=区三区| 黄动漫视频高清在线| 久久riav二区三区| 色99之美女主播在线视频| 亚洲一区二区三区四区五区黄| 成年人免费看的视频| 日韩一区欧美一区|