`
netxdiy
  • 浏览: 714673 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

SQL Server 2005/2008/2012中应用分布式分区视图

 
阅读更多

SQL Server 2008中SQL应用系列--目录索引

  自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实例间传输的数据总量。


邀月注:本文版权由邀月和CSDN共同所有,转载请注明出处。
助人等于自助! 3w@live.cn



分享到:
评论

相关推荐

    SQL Server分布式分区视图分解数据表

    在SQL Server中,分布式分区视图基于分布式查询的概念,它能够将数据从一个或多个数据库聚合到一个视图中,让应用程序看起来像是在一个服务器上操作所有数据。这对于构建大型分布式数据库环境尤其有用,因为它们可以...

    浅析SQL Server 2000分布式分区视图.pdf

    微软承诺在后续版本的SQL Server中继续发展分布式分区视图技术,以提供更强的可扩展性和更好的性能。这个特性尤其在处理大量数据和需要极高数据库性能的场景中,如TPC-C基准测试中表现优异。 总结而言,SQL Server ...

    SQL Server2000分布式分区视图应用研究.pdf

    SQL Server 2000是微软公司推出的一个数据库管理系统,其中分布式分区视图是其重要的新特性之一。该特性的提出是为了更好地处理大规模数据,特别是在多服务器环境下实现数据的高效管理和查询。 分布式分区视图的...

    基于SQL SERVER的分布式数据库设计与实现

    SQL Server 支持创建分布式分区视图来实现这一目标。通过定义分区键并创建对应的分区表,再通过视图将这些分区表组合起来,即可实现对整个数据集的访问。这种方法尤其适用于频繁按分区键进行数据筛选的场景。 #####...

    Microsoft SQL Server 2005 Native Client

    2. **支持新特性**:它支持SQL Server 2005引入的新特性,如行版本控制、分区视图、用户定义的函数和存储过程等。 3. **安全性增强**:支持集成Windows身份验证,提供更安全的连接方式,同时支持SQL Server的角色...

    数据库原理与应用教程:基于SQL+Server+2005.rar

    1. 分布式数据库:了解分布式数据库的概念,以及SQL Server 2005中的分布式查询和复制功能。 2. 数据仓库与BI:简单介绍数据仓库的构建,以及SQL Server Analysis Services (SSAS) 和Reporting Services (SSRS) 在...

    第二章SQLserver2005概述

    5. 分布式分区视图:支持跨多个服务器的大规模数据分布和查询优化。 6. 改进的安全性:包括角色基础的访问控制和细粒度权限管理。 安装SQL Server 2005涉及选择合适的版本(如企业版、标准版、开发版或个人版),并...

    SQL server 2000 分区表和分区视图.docx

    在SQL Server 2000中,有两种类型的分区视图:本地分区视图和分布式分区视图。本地分区视图的所有成员表都位于同一个SQL Server实例上,而分布式分区视图的成员表可能分布在不同的服务器上,形成了所谓的数据库...

    SQL server 2000 分区表和分区视图.pdf

    本地分区视图的所有成员表都位于同一个SQL Server实例上,而分布式分区视图则允许成员表分布在不同的服务器上,从而实现更广泛的分布和负载均衡。 **本地分区视图** 提供了一种在单个服务器上管理和查询分区数据的...

    SQL Server2005 English

    - **分布式分区视图**:改进了分布式数据库的性能和可用性。 - **故障转移集群**:提高系统高可用性和灾难恢复能力。 - **64位系统支持**:充分利用现代服务器的内存和处理器资源。 - **索引视图与计算列索引**:...

    SQL Server 2000分布式数据库系统的构建.pdf

    文章中还详细介绍了分布式分区视图的创建以及它在分布式查询中的应用,这是实现高效数据检索和处理的重要技术手段。 4. 分布式数据库的数据分区 数据分区***组,这样可以提高查询性能和数据库的可伸缩性。在分布式...

    SQL Server 2005内幕故事系列之一:SQL Server 2005 预览

    SQL Server 2005是微软推出的一款强大的关系型数据库管理系统,...而压缩包中的"msft080305vxam.wmv"文件,可能是微软在2008年3月发布的一次关于SQL Server 2005的演示或讲解视频,可能会深入探讨上述提到的一些特性。

    Microsoft SQL Server中的分布式/异构查询处理

    大学生在线实习及就业成才互动服务平台项目提出了一个在Microsoft SQL Server...最后,结构本身是可扩展的,以支持新的数据源加入,这是系统的一个关键可扩展点,以使关系引擎可以进行全文检索和分布式分区视图等新功能。

    浅析SQL Server2005在实际生活中的应用.pdf

    SQL Server 2005还提供了SQL服务中介,这允许构建分布式和异步应用框架,从而为大规模应用程序提供更强大的支持。通告服务则支持创建丰富的通知类应用程序,使信息可以实时推送给不同的设备和平台。 此外,SQL ...

    新概念SQL Server 2005教程

    SQL Server 2005的复制功能允许数据在多个服务器之间同步,支持发布/订阅模型,广泛应用于分布式系统和数据分发。 九、备份与恢复 SQL Server 2005提供了多种备份选项,如完整备份、差异备份和日志备份,以及灵活的...

    基于SQL Server2000分布式查询及更新的应用研究.pdf

    - 不支持对链接服务器上的分布式分区视图进行查询,这可能需要在应用层面进行处理。 - 安全性是另一个重要的考虑因素,需要确保正确的权限设置和安全策略,防止未授权的访问。 6. 分布式数据库在企业中的应用 ...

    SQL Server 2005 教程.ppt

    7. 集成的数据仓库和商业智能工具:SQL Server 2005集成了数据仓库和商业智能解决方案,如分析服务(Analysis Services)的增强,支持多维数据集、ROLAP维度存储、分布式分区立方体等,方便进行数据分析和决策制定。...

    SQL Server 2005管理最重要特点

    10. **增强复制功能**:SQL Server 2005的复制功能得到了显著增强,包括对分布式数据库的全面DDL复制、改进的监控性能、Oracle到SQL Server的复制支持、多HTTP路径的合并复制以及对合并复制的可升级性改进。...

    sql server 2005 samples

    SQL Server 2005是微软推出的一款关系型数据库管理系统,它在企业级应用中扮演着重要的角色。"sql server 2005 samples" 是一套由微软官方提供的示例数据库和应用程序,旨在帮助开发者更好地理解和掌握SQL Server ...

    SQL server 2005 教程及使用技巧

    4. **复制技术**: SQL Server 2005的复制功能允许数据在多个服务器之间同步,适用于分布式环境和数据分发。 5. **服务与代理**: 了解SQL Server服务(如SQL Server Agent)的作用,以及如何调度和管理作业。 ### ...

Global site tag (gtag.js) - Google Analytics