• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

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

mysql 搞代码 4年前 (2022-01-09) 59次浏览 已收录 0个评论

SQL Server 2008中S本文来源gaodai$ma#com搞$代*码*网(QL 应用 系列–目录索引 自2000版本起,SQL Server企业版中引入 分布式 分区 视图 ,允许你为分布在不同的SQL 实例的两个或多个水平 分区 表创建 视图 。 简要步骤如下:根据Check约束中定义的一组把大表分割成更小的一些表。Check约束确

<link href=”/js/syntaxhighlighter/SyntaxHighlighter.css” rel=”stylesheet” type=”text/css” />

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)而不创建链接服务器,并创建测试数据库和表。

<span>/*</span><span>******** 创建一个<strong>分布式</strong><strong>分区</strong><strong>视图</strong> **************</span><span>*/</span><span>/*</span><span>******** [email protected] 邀月 **************</span><span>*/</span><span>USE</span><span> master</span><span>GO</span><span>EXEC</span><span> sp_addlinkedserver</span><span>'</span><span>AP4\NET2013</span><span>'</span><span>,N</span><span>'</span><span>SQL Server</span><span>'</span><span>GO</span><span>--</span><span> 跳过远程实例架构表的检查,以提升性能,邀月注</span><span>EXEC</span> sp_serveroption <span>'</span><span>AP4\NET2013</span><span>'</span>, <span>'</span><span>lazy schema validation</span><span>'</span>, <span>'</span><span>true</span><span>'</span><span>GO</span><span>--</span><span>创建测试数据库</span><span>IF</span> <span>NOT</span> <span>EXISTS</span> (<span>SELECT</span><span> name</span><span>FROM</span><span> sys.databases</span><span>WHERE</span> name <span>=</span> <span>'</span><span>RemoteViewTest2012</span><span>'</span><span>)</span><span>BEGIN</span><span>CREATE</span> <span>DATABASE</span><span> RemoteViewTest2012</span><span>END</span><span>GO</span><span>--</span><span>打开测试库</span><span>Use</span><span> RemoteViewTest2012</span><span>GO</span><span>--</span><span>创建上海分公司的点击表</span><span>CREATE</span> <span>TABLE</span><span> dbo.WebHits_ShangHai(WebHitID </span><span>uniqueidentifier</span> <span>NOT</span> <span>NULL</span><span>,WebSite </span><span>varchar</span>(<span>20</span>) <span>NOT</span> <span>NULL</span><span> ,HitDT </span><span>datetime</span> <span>NOT</span> <span>NULL</span><span>,</span><span>CHECK</span> (WebSite <span>=</span> <span>'</span><span>ShangHai</span><span>'</span><span>),</span><span>CONSTRAINT</span> PK_WebHits <span>PRIMARY</span> <span>KEY</span> (WebHitID, WebSite))


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:SQL Server 2005/2008/2012中应用分布式分区视图

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址