MSSQL Server分布式查询

澳门新葡亰3522平台游戏 2

核心提示:SQL
Server所谓的分布式查询是能够访问存放在同一部计算机或不同计算机上的SQL
Server或不同种类的数据源

MSSQlServer所谓的分布式查询(Distributed
Query)是能够访问存放在同一部计算机或不同计算机上的SQL
Server或不同种类的数据源, 从概念上来说分布式查询与普通查询区别
它需要连接多个MSSQL服务器也就是具有多了数据源.实现在服务器跨域或跨服务器访问.
而这些查询是否被使用完全看使用的需要.

SQL
Server所谓的分布式查询是能够访问存放在同一部计算机或不同计算机上的SQL
Server或不同种类的数据源, 从概念上来说分布式查询与普通查询区别
它需要连接多个MSSQL服务器也就是具有多了数据源。实现在服务器跨域或跨服务器访问。
而这些查询是否被使用完全看使用的需要。

 

本篇将演示利用SQL ServerExpress链接远程SQL
Server来获取数据方式来详细说明分布式查询需要注意细节。先看一下系统架构数据查询基本处理:

本篇将演示利用SQlExpress链接远程SQlServer来获取数据方式来详细说明分布式查询需要注意细节.先看一下系统架构数据查询基本处理:

澳门新葡亰3522平台游戏,当然如果采用了分布式查询
我们系统采取数据DataBase也就可能在多个远程[Remote Server]上访问时:

 澳门新葡亰3522平台游戏 1

如上截取系统架构中关于数据与缓存流向中涉及的分布式查询业务,
当我们从客户端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 访问接口之间的连接 如下图:

 

从上图可以看出。客户端借助OLEDB接口可以访问Oracle/MS Jet/MS
SQL/ODBC/第三方等这些丰富数据源来我们分布式查询提供数据。
说了这么多关于OLEDB底层支持。 关于在MS SQL
2005中则支持两种方式来进行分布式查询:

 

使用添加链接服务器方式

 

使用特定名称及特定数据源来直接指定

 

其实这两种方式在实际运用中是有区别的:

 

方式A:Add Link
Server方式建立服务器之间关联。创建一个链接的服务器,使其允许对分布式的、针对
OLE DB 数据源的异类查询进行访问。 一般适用于持久的数据操作
对于数据量偏大 服务器之间交付时间长特点。

 

方式B: Add Host Name 利用域来唯一识别数据库以及数据库表对象。
来实现跨服务器访问。 这种方式一般比较简单
主要适用于对数据需求临时性查询是使用偏多。 不适合做大批量数据提取。
有性能瓶颈。

当然如果采用了分布式查询
我们系统采取数据DataBase也就可能在多个远程[Remote Server]上访问时: 

《2》分布式查询实现

 澳门新葡亰3522平台游戏 2

在进行实现分布式查询之前。本次测试Demo对应的SQL版本:

 

确定SQL Server版本后如下会演示两种方式来实现分布式查询,并对Distributed
Query中详细细节进行说明。

 

《2.1》链接服务器查询