SQL Server 2005/2008/2012中应用分布式分区视图
自2000版本起,SQL Server企业版中引入分布式分区视图,允许你为分布在不同的SQL 实例的两个或多个水平分区表创建视图。
简要步骤如下:根据Check约束中定义的一组值把大表分割成更小的一些表。Check约束确保每个小表保存着不能保存在其他表的唯一数据。然后使用Union All创建分布式分区视图,把所有这些小表联结成单独的结果集。
这样对性能的改善是有益的,例如,如果视图根据日期分区,并用查询来返回仅保存在一个分区表中的行,那么SQL Server会智能地只搜索一个分区而不是分布式分区视图中的所有表。
我们假设一个场景,某公司成立上海和北京分公司,分别有各自的SQL Server实例来保存网站数据,都希望用一个表跟踪网站点击。点击量非常大。此时,需要一个视图以在单个视图中引用各自的表。公司希望能查询任意一个服务器,并且返回相同的数据或各自分公司的数据。
下面我们通过实例来演示这个场景的具体应用。假定有两个实例:AP4\NET2012和AP4\NET2013(本文所有示例均在SQL Server 2008环境下通过)。
一、创建链接服务器,当然也可以通过OpenRowset(http://msdn.microsoft.com/zh-cn/library/ms190312.aspx)而不创建链接服务器,并创建测试数据库和表。
- /********* 创建一个分布式分区视图 ***************/
- /********* 3w@live.cn 邀月 ***************/
- USE master
- GO
- EXEC sp_addlinkedserver
- 'AP4\NET2013',
- N'SQL Server'
- GO
- -- 跳过远程实例架构表的检查,以提升性能,邀月注
- EXEC sp_serveroption 'AP4\NET2013', 'lazy schema validation', 'true'
- GO
- --创建测试数据库
- IF NOT EXISTS (SELECT name
- FROM sys.databases
- WHERE name = 'RemoteViewTest2012')
- BEGIN
- CREATE DATABASE RemoteViewTest2012
- END
- GO
- --打开测试库
- Use RemoteViewTest2012
- GO
- --创建上海分公司的点击表
- CREATE TABLE dbo.WebHits_ShangHai
- (WebHitID uniqueidentifier NOT NULL,
- WebSite varchar(20) NOT NULL ,
- HitDT datetime NOT NULL,
- CHECK (WebSite = 'ShangHai'),
- CONSTRAINT PK_WebHits PRIMARY KEY (WebHitID, WebSite))
第二个实例:
- /*************** 实例 AP4\NET2013(SQL Server 2008) *********/
- /********* 3w@live.cn 邀月 ***************/
- USE master
- GO
- EXEC sp_addlinkedserver
- 'AP4\NET2012',
- N'SQL Server'
- GO
- -- 跳过远程实例架构表的检查,以提升性能,邀月注
- EXEC sp_serveroption 'AP4\NET2012', 'lazy schema validation', 'true'
- GO
- IF NOT EXISTS (SELECT name
- FROM sys.databases
- WHERE name = 'RemoteViewTest2012')
- BEGIN
- CREATE DATABASE RemoteViewTest2012
- END
- GO
- --打开测试库
- Use RemoteViewTest2012
- GO
- --创建北京分公司的点击表
- CREATE TABLE dbo.WebHits_BeiJing
- (WebHitID uniqueidentifier NOT NULL,
- WebSite varchar(20) NOT NULL ,
- HitDT datetime NOT NULL,
- CHECK (WebSite = 'BeiJing'),
- CONSTRAINT PK_WebHits PRIMARY KEY (WebHitID, WebSite))
二、在两个实例中分别创建视图
- /*************** 实例 AP4\NET2012(SQL Server 2008) *********/
- /********* 3w@live.cn 邀月 ***************/
- --打开测试库
- Use RemoteViewTest2012
- GO
- --创建分区视图
- CREATE VIEW dbo.v_WebHits AS
- SELECT WebHitID,
- WebSite,
- HitDT
- FROM RemoteViewTest2012.dbo.WebHits_ShangHai
- UNION ALL
- SELECT WebHitID,
- WebSite,
- HitDT
- FROM [AP4\NET2013].RemoteViewTest2012.dbo.WebHits_BeiJing
- GO
- /*************** 实例 AP4\NET2013(SQL Server 2008) *********/
- /********* 3w@live.cn 邀月 ***************/
- --打开测试库
- Use RemoteViewTest2012
- GO
- --创建分区视图
- CREATE VIEW dbo.v_WebHits AS
- SELECT WebHitID,
- WebSite,
- HitDT
- FROM RemoteViewTest2012.dbo.WebHits_BeiJing
- UNION ALL
- SELECT WebHitID,
- WebSite,
- HitDT
- FROM [AP4\NET2012].RemoteViewTest2012.dbo.WebHits_ShangHai
- GO
三、插入测试数据
我们可以选择任意一个实例中插入,下面我们选择AP4\NET2013
- /*************** 实例 AP4\NET2013(SQL Server 2008) *********/
- /********* 3w@live.cn 邀月 ***************/
- ----要保证插入,必须打开XACT_ABORT开关,并开启分布式事务协调器,邀月注
- --打开测试库
- Use RemoteViewTest2012
- GO
- SET XACT_ABORT ON
- INSERT dbo.v_WebHits
- (WebHitID, WebSite, HitDT)
- VALUES(NEWID(), 'ShangHai', GETDATE())
- INSERT dbo.v_WebHits
- (WebHitID, WebSite, HitDT)
- VALUES(NEWID(), 'BeiJing', GETDATE())
注意,如果该实例所在的服务器上没有启用MSDTC(Microsoft 分布式事务处理协调器),会抛出一个错误:

此时在命令行中输入Net start msdtc以启用该服务。


如果还是不能正常启动MSDTC,请查阅MSDN(http://msdn.microsoft.com/zh-cn/library/aa561924%28BTS.10%29.aspx)以获取帮助。
四、进行分布式查询
此时,我们在任意一个实例查询的结果都是一致的,也正是我们想要的。
- /*************** 实例 AP4\NET2013(SQL Server 2008) *********/
- /********* 3w@live.cn 邀月 ***************/
- /***** 分布式查询 **************/
- ----AP4\NET2013上查询
- --打开测试库
- Use RemoteViewTest2012
- GO
- SET XACT_ABORT ON
- SELECT WebHitID, WebSite, HitDT
- FROM dbo.v_WebHits
- SELECT WebHitID, WebSite, HitDT
- FROM [AP4\NET2012].RemoteViewTest2012.dbo.WebHits_ShangHai

- ----AP4\N ET2012上查询
- --打开测试库
- Use RemoteViewTest2012
- GO
- SET XACT_ABORT ON
- SELECT WebHitID, WebSite, HitDT
- FROM dbo.v_WebHits
- SELECT WebHitID, WebSite, HitDT
- FROM [AP4\NET2013].RemoteViewTest2012.dbo.WebHits_BeiJing

我们欣喜地看到,SQL Server并没有在基础分区表中插入冗余数据,而是自动分发到了Check所约定的相应的表中,这得益于MSDTC的功劳。

注意:创建分布式视图的注意事项和必要条件,请看MSDN(http://msdn.microsoft.com/zh-cn/library/ms188299.aspx)。
小结:分布式分区视图允许我们跨多个SQL Server实例划分数据。对于超大型数据库和拥有大量事务和读操作的SQL Server实例来说,这种设计让我们获益良多。根据被查询的视图,SQL Server能确定只查询本地分区表是否能满足某个查询请求,远程表是否需要查询,最终,SQL Server会最大限度地减少SQL Server实例间传输的数据总量。
助人等于自助! 3w@live.cn
SQL Server 2005/2008/2012中应用分布式分区视图的更多相关文章
- SQL SERVER 2005/2008 中关于架构的理解(二)
本文上接SQL SERVER 2005/2008 中关于架构的理解(一) 架构的作用与示例 用户与架构(schema)分开,让数据库内各对象不再绑在某个用户账号上,可以解决SQL SERVE ...
- SQL SERVER 2005/2008 中关于架构的理解(一)
SQL SERVER 2005/2008 中关于架构的理解(一) 在一次的实际工作中碰到以下情况,在 SQL SERVER 2008中,新建了一个新用户去访问几张由其他用户创建的表,但是无法进行查询, ...
- 【转】SQL SERVER 2005/2008 中关于架构的理解
在一次的实际工作中碰到以下情况,在 SQL SERVER 2008中,新建了一个新用户去访问几张由其他用户创建的表,但是无法进行查询,提示“对象名'CustomEntry' 无效.”.当带上了架构名称 ...
- 怎样修改SQL Server 2005/2008的系统存储过程(转)
我们知道,SQL Server 2005/2008的系统存储过程在正常情况下是无法直接修改的. 尽管本文是介绍怎样修改它的,但在这里,我还是建议大家尽量不要去修改它.(好像有点绕哈...) OK,闲话 ...
- 【缓存】Sql Server 2005/2008 SqlCacheDependency查询通知的使用总结
Sql server 7.0/2000下 SqlCacheDependency使用轮询的方式进行缓存失效检查, 虽然ms说对服务器压力不大, 但还是有一些的, 而且对于不常改动的混存内容无休止的轮询感 ...
- SQL Server 2005,2008 正则表达式 替换函数应用详解
CREATE function dbo.regexReplace ( @source ntext, --原字符串 ), --正则表达式 ), --替换值 , --是否是全局替换 --是否忽略大小写 ) ...
- SQL Server 2005/2008压缩数据库日志的方法
适用于SQL Server 2005的方法 Backup Log DNName WITH no_log GO DUMP TRANSACTION DNName WITH no_log GO USE DN ...
- PHP连接Microsoft SQL Server 2005/2008
PHP自带的MSSQL扩展php_mssql.dll原来是给SQL Server 2000用的,难怪连接不上2008?! -_-!!要使用SQL Server 2005以上版本,就要用到微软为PHP提 ...
- Sql Server 2005/2008数据库被标记为“可疑”/“质疑”的问题
日常对Sql Server 2005关系数据库进行操作时,有时对数据库(如:Sharepoint网站配置数据库名Sharepoint_Config)进行些不正常操作如数据库在读写时而无故停止数据库,从 ...
随机推荐
- php 数据库类
<?php /** * 对Yii2数据封装 * @author nike@youfumama.com * @date 2017-03-08 * 抽象类不能被实例化 * eg1: select u ...
- SpringMVC之八:基于SpringMVC拦截器和注解实现controller中访问权限控制
SpringMVC的拦截器HandlerInterceptorAdapter对应提供了三个preHandle,postHandle,afterCompletion方法. preHandle在业务处理器 ...
- POJ 2566 Bound Found(尺取法,前缀和)
Bound Found Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 5207 Accepted: 1667 Spe ...
- [转]SVN 乱码问题
以下来自:http://godchenmeng.iteye.com/blog/797727 最近研究SVN.发现在创建补丁包的时候出现这种情况. 在文件顶部不论是什么代码都会变成乱码.在文件中如果有注 ...
- python中break continue exit() pass区别
1.break break是终止本次循环,比如你很多个while循环,你在其中一个while循环里写了一个break,满足条件,只会终止这个while里面的循环,程序会跳到上一层while循环继续往下 ...
- 【语音识别】Microsoft Speech Platform 自学笔记2 环境要求与安装过程
笔记人:又吹风 时 间:2012/12/16 主要内容:Microsoft Speech Platform的环境要求与安装过程. 上次也说过了,当前Microsoft Speech Platform最 ...
- Windows下安装GCC
1.GCC编译器的选择 Windows下最常见的安装GCC的方式有两种:Cygwin和MinGW.本文主要介绍MinGW的安装配置. 2.下载MinGW 下载地址:http://sourceforge ...
- c++ 双向链表操作总结
第一.包含DoubleLinkNode 模板类和DoubleLinkList 模板类 #pragma once #include<iostream> using namespace std ...
- MySQL多实例介绍
我们前面已经做了MySQL数据库的介绍以及为什么选择MySQL数据库,最后介绍了MySQL数据库在Linux系统下的多种安装方式,以及讲解了MySQL的二进制方式单实例安装.基础优化等,下面给大家讲解 ...
- PHP5缓存插件
1.1操作码介绍及缓存原理 当客户端请求一个PHP程序时,服务器的PHP引擎会解析到该PHP程序,并将其变异为特定的操作码文件(OperateCode opcode),这是要执行的PHP代码的一种二进 ...