zoukankan      html  css  js  c++  java
  • 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)而不创建链接服务器,并创建测试数据库和表。

    1. /********* 创建一个分布式分区视图 ***************/  
    2. /********* 3w@live.cn 邀月 ***************/  
    3.   
    4. USE master  
    5. GO  
    6. EXEC sp_addlinkedserver  
    7. 'AP4\NET2013',  
    8. N'SQL Server'  
    9. GO  
    10.   
    11. -- 跳过远程实例架构表的检查,以提升性能,邀月注  
    12. EXEC sp_serveroption 'AP4\NET2013', 'lazy schema validation', 'true'  
    13. GO  
    14.   
    15. --创建测试数据库  
    16. IF NOT EXISTS (SELECT name  
    17. FROM sys.databases  
    18. WHERE name = 'RemoteViewTest2012')  
    19. BEGIN  
    20. CREATE DATABASE RemoteViewTest2012  
    21. END  
    22. GO  
    23. --打开测试库  
    24. Use RemoteViewTest2012  
    25. GO  
    26.   
    27. --创建上海分公司的点击表  
    28. CREATE TABLE dbo.WebHits_ShangHai  
    29. (WebHitID uniqueidentifier NOT NULL,  
    30. WebSite varchar(20) NOT NULL ,  
    31. HitDT datetime NOT NULL,  
    32. CHECK (WebSite = 'ShangHai'),  
    33. CONSTRAINT PK_WebHits PRIMARY KEY (WebHitID, WebSite))  

    第二个实例:

    1. /*************** 实例 AP4\NET2013(SQL Server 2008) *********/  
    2. /********* 3w@live.cn 邀月 ***************/  
    3. USE master  
    4. GO  
    5. EXEC sp_addlinkedserver  
    6. 'AP4\NET2012',  
    7. N'SQL Server'  
    8. GO  
    9.   
    10. -- 跳过远程实例架构表的检查,以提升性能,邀月注  
    11. EXEC sp_serveroption 'AP4\NET2012', 'lazy schema validation', 'true'  
    12. GO  
    13.   
    14. IF NOT EXISTS (SELECT name  
    15. FROM sys.databases  
    16. WHERE name = 'RemoteViewTest2012')  
    17. BEGIN  
    18. CREATE DATABASE RemoteViewTest2012  
    19. END  
    20. GO  
    21.   
    22. --打开测试库  
    23. Use RemoteViewTest2012  
    24. GO  
    25.   
    26. --创建北京分公司的点击表  
    27. CREATE TABLE dbo.WebHits_BeiJing  
    28. (WebHitID uniqueidentifier NOT NULL,  
    29. WebSite varchar(20) NOT NULL ,  
    30. HitDT datetime NOT NULL,  
    31. CHECK (WebSite = 'BeiJing'),  
    32. CONSTRAINT PK_WebHits PRIMARY KEY (WebHitID, WebSite))  

    二、在两个实例中分别创建视图

    1. /*************** 实例 AP4\NET2012(SQL Server 2008) *********/  
    2. /********* 3w@live.cn 邀月 ***************/  
    3.   
    4. --打开测试库  
    5. Use RemoteViewTest2012  
    6. GO  
    7.   
    8. --创建分区视图  
    9. CREATE VIEW dbo.v_WebHits AS  
    10. SELECT WebHitID,  
    11. WebSite,  
    12. HitDT  
    13. FROM RemoteViewTest2012.dbo.WebHits_ShangHai  
    14. UNION ALL  
    15. SELECT WebHitID,  
    16. WebSite,  
    17. HitDT  
    18. FROM [AP4\NET2013].RemoteViewTest2012.dbo.WebHits_BeiJing  
    19. GO  
    20.   
    21. /*************** 实例 AP4\NET2013(SQL Server 2008) *********/  
    22. /********* 3w@live.cn 邀月 ***************/  
    23.   
    24. --打开测试库  
    25. Use RemoteViewTest2012  
    26. GO  
    27.   
    28. --创建分区视图  
    29. CREATE VIEW dbo.v_WebHits AS  
    30. SELECT WebHitID,  
    31. WebSite,  
    32. HitDT  
    33. FROM RemoteViewTest2012.dbo.WebHits_BeiJing  
    34. UNION ALL  
    35. SELECT WebHitID,  
    36. WebSite,  
    37. HitDT  
    38. FROM [AP4\NET2012].RemoteViewTest2012.dbo.WebHits_ShangHai  
    39. GO  

    三、插入测试数据

    我们可以选择任意一个实例中插入,下面我们选择AP4\NET2013

    1. /*************** 实例 AP4\NET2013(SQL Server 2008) *********/  
    2. /********* 3w@live.cn 邀月 ***************/  
    3. ----要保证插入,必须打开XACT_ABORT开关,并开启分布式事务协调器,邀月注  
    4.   
    5. --打开测试库  
    6. Use RemoteViewTest2012  
    7. GO  
    8.   
    9. SET XACT_ABORT ON  
    10. INSERT dbo.v_WebHits  
    11. (WebHitID, WebSite, HitDT)  
    12. VALUES(NEWID(), 'ShangHai', GETDATE())  
    13.   
    14. INSERT dbo.v_WebHits  
    15. (WebHitID, WebSite, HitDT)  
    16. VALUES(NEWID(), 'BeiJing', GETDATE())  
    17.   
    18.    

      注意,如果该实例所在的服务器上没有启用MSDTC(Microsoft 分布式事务处理协调器),会抛出一个错误:

    邀月工作室

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

    邀月工作室

    邀月工作室

      如果还是不能正常启动MSDTC,请查阅MSDN(http://msdn.microsoft.com/zh-cn/library/aa561924%28BTS.10%29.aspx)以获取帮助。

    四、进行分布式查询

      此时,我们在任意一个实例查询的结果都是一致的,也正是我们想要的。

    1. /*************** 实例 AP4\NET2013(SQL Server 2008) *********/  
    2. /********* 3w@live.cn 邀月 ***************/  
    3. /***** 分布式查询  **************/  
    4.   
    5. ----AP4\NET2013上查询  
    6. --打开测试库  
    7. Use RemoteViewTest2012  
    8. GO  
    9. SET XACT_ABORT ON  
    10.   
    11. SELECT WebHitID, WebSite, HitDT  
    12. FROM dbo.v_WebHits  
    13.   
    14. SELECT WebHitID, WebSite, HitDT  
    15. FROM [AP4\NET2012].RemoteViewTest2012.dbo.WebHits_ShangHai   

    1. ----AP4\N ET2012上查询  
    2. --打开测试库  
    3. Use RemoteViewTest2012  
    4. GO  
    5.   
    6. SET XACT_ABORT ON  
    7.   
    8. SELECT WebHitID, WebSite, HitDT  
    9. FROM dbo.v_WebHits  
    10.   
    11. SELECT WebHitID, WebSite, HitDT  
    12. 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实例间传输的数据总量。


    http://blog.csdn.net/downmoon/article/details/7452018
  • 相关阅读:
    ajax异步服务器获取时间
    JavaScript基本知识
    JavaScript使用button提交表单
    spring与hibernate整合
    Spring的事务属性
    注解方式实现Spring声明式事务管理
    svn的安装使用
    sbn
    恢复oracle中误删除drop掉的表
    ORA-20000: ORU-10027: buffer overflow, limit of 2000 bytes的解决办法
  • 原文地址:https://www.cnblogs.com/shihao/p/2450932.html
Copyright © 2011-2022 走看看