分布式视图:

1.将大表分割到多个服务器上存储

2.物理上与逻辑上都存在多个表

3.通过视图实现对分布到多个服务器表进行访问

4.整合网络负载平衡

链接两台数据库:

建立同样的数据结构:

 create table Sales(c1 int not null,c2 int)
alter table Sales
add constraint pk_Sales_c1 primary key (c1)
alter table Sales
add constraint ck_Sales_c1 check(c1 between 1 and 100)
--后一太数据库 101---200

点击新建链接服务器:

创建视图:

 create view v_sales
as
select * from Sales union all
select * from [localhost\Src1] HRDB.dbo.Sales

在第二台服务器上建立与第一台服务器的链接 和上面的步骤一样

执行下面的语句:

 insert v_sales values (2,2)
insert v_sales values(200,200)

报错:(保证分布式事物可用)

开启:

在次执行报错:

改成这样:

 set xact_abort on
insert v_sales values (2,2)
insert v_sales values(200,200)

执行下面的语句:

结果如下:

执行下面的更新语句:

第一台服务器没有全在第二台服务器上:

由此可见:分布式视图可以有效的解决系统性能问题,将大表不同的记录范围---分在不同的服务器上,然后通过视图进行表的操作,有效的平衡服务器负载的流量

分割提升数据的访问:

数据的放置:

1.数据放置的原则:

1.在不同的无力磁盘或RAID上创建文件组

2.将常用的连接查询中的表放置到不同的文件组

3.将访问频繁的大表放置到不同的文件组

4.日志文件存放在单独的磁盘

5.将Tempdb数据库放置到快速的磁盘或RAID上

创建分区函数:

	create partition function fn_SalesOrderdetial (int)
as range left
for values(10000,50000)

创建文件组:

alter database HRDB
add filegroup fg1
alter database HRDB
add filegroup fg2
alter database HRDB
add filegroup fg3

指定关联:

	alter database HRDB
add file
(
name='data1',
filename='e:\data1.ndf'
)to filegroup fg1
alter database HRDB
add file
(
name='data2',
filename='e:\data2.ndf'
)to filegroup fg2 alter database HRDB
add file
(
name='data3',
filename='f:\data1.ndf'
)to filegroup fg3

创建分区方案:

	--创建分区方案
create partition scheme sch_SalesOrderDetail
--使用的分区函数
as partition fn_SalesOrderdetial
--放入的文件夹
to(fg1,fg2,fg3)

插入表数据:

        insert into SalesOrderDetail(OrderDetailID, UnitPrice,Qry )
select SalesOrderDetailID,UnitPrice,OrderQty from OrderDetail

查询:

        set statistics io on
select OrderDetailID,UnitPrice,Qry from SalesOrderDetail where UnitPrice>200 --0.419
set statistics io off

创建索引:

	create nonclustered index nc_Salesorderdetail_UnitPrice on      
SalesOrderDetail(UnitPrice )
include (OrderDetailID,Qry)

再次执行:

        set statistics io on
select OrderDetailID,UnitPrice,Qry from SalesOrderDetail where UnitPrice>200 --0.193
set statistics io off

加上条件:

	set statistics io on
select OrderDetailID,UnitPrice,Qry from SalesOrderDetail where UnitPrice>200 and OrderDetailID=6000 --0.07
set statistics io off

创建另外一个非聚集索引对OrderDetailID进行物理排序:

	create nonclustered index nc_SalseOrderDetail_OrderDetaillID on SalesOrderDetail(OrderDetailID)
include(unitprice,Qry)

执行:

        set statistics io on
select OrderDetailID,UnitPrice,Qry from SalesOrderDetail where UnitPrice>200 and OrderDetailID=6000 --0.07
set statistics io off

SqlServer性能优化分割提升性能分布式视图(七)的更多相关文章

  1. 性能优化——Web前端性能优化

    核心知识点: 1.排查网站性能瓶颈的手法:分析各个环节的日志,找出异常部分 2.Web前端:网站业务逻辑之前的部分(浏览器.图片服务.CDN) 3.优化手段 1)浏览器优化 (1)减少http请求 a ...

  2. web性能优化-网络传输性能优化

    浏览器工作原理:https://www.cnblogs.com/thonrt/p/10008220.html 浏览器渲染原理: https://www.cnblogs.com/thonrt/p/100 ...

  3. Android App性能优化笔记之一:性能优化是什么及为什么?

    By Long Luo   周星驰的电影<功夫>里面借火云邪神之口说出了一句至理名言:“天下武功,唯快不破”. 在移动互联网时代,同样如此,留给一个公司的窗口往往只有很短的时间,如何把握住 ...

  4. 微擎开启性能优化里面的性能优化memcache内存优化及数据库读写分离

    http://www.mitusky.com/forum.php?mod=viewthread&tid=3135 [微擎 安装使用] 微擎开启性能优化里面的性能优化memcache内存优化及数 ...

  5. Java 架构师+高并发+性能优化+Spring boot大型分布式项目实战

    视频课程内容包含: 高级 Java 架构师包含:Spring boot.Spring cloud.Dubbo.Redis.ActiveMQ.Nginx.Mycat.Spring.MongoDB.Zer ...

  6. Android app 性能优化的思考--性能卡顿不好的原因在哪?

    说到 Android 系统手机,大部分人的印象是用了一段时间就变得有点卡顿,有些程序在运行期间莫名其妙的出现崩溃,打开系统文件夹一看,发现多了很多文件,然后用手机管家 APP 不断地进行清理优化 ,才 ...

  7. 2018/09/17《涂抹MySQL》【性能优化及诊断】学习笔记(七)

    读 第十三章<MySQL的性能优化与诊断> 总结 一说性能优化,整个人都像被打了鸡血一样

  8. iOS 性能优化之业务性能监控

    业务性能监控, 在人工的在业务的开始和结束处打点上报,然后后台统计达到监控目的, 是性能优化里比较重要的一个维度.具体来说就是测试方法操作执行的时间损耗,可能是同步 也可能是异步的.测试的方法大概有如 ...

  9. react第八单元(什么是纯函数-组件的性能优化-pureComponent-组件性能优化的原理)

    课程目标 理解纯函数 熟练掌握组件性能优化的几种技巧 pureComponent和Component的区别 #知识点 一个函数的返回结果只依赖于它的参数,并且在执行过程里面没有副作用,我们就把这个函数 ...

随机推荐

  1. 节约内存:Instagram的Redis实践(转)

    一.问题:     数据库表数据量极大(千万条),要求让服务器更加快速地响应用户的需求. 二.解决方案:      1.通过高速服务器Cache缓存数据库数据      2.内存数据库 三.主流解Ca ...

  2. CheckLogin

    # encoding: utf-8 # Creator:耿亚月 Creation time:2017-1-1 # Modifier:耿亚月 Modification time:2017-1-2 #fi ...

  3. spider_jpg

    __author__ = 'sus' #urllib模块提供了读取Web页面数据的接口import urllib#re模块主要包含了正则表达式import re#定义一个getHtml()函数def ...

  4. 【FPGA】【代码】资源优化,结构优化

    资源优化 原始资源 定义时初始化和复位电路初始化都起作用,删除定义的初值后 将always块描述的组合逻辑变为时序逻辑后

  5. ORCALE复制表结构

    1.oracle 复制表结构 不要内容 create table 表1 as select * from 表2 where 1=2 2.oracle 复制表结构 要内容 create table 表1 ...

  6. HDFS读写数据块--${dfs.data.dir}选择策略

    最近工作需要,看了HDFS读写数据块这部分.不过可能跟网上大部分帖子不一样,本文主要写了${dfs.data.dir}的选择策略,也就是block在DataNode上的放置策略.我主要是从我们工作需要 ...

  7. python 打印 网格

    #/usr/bin/python # -*- coding:utf-8 -*- # width 单个网格有多少个 - 宽度# height 单个网格有多少个 | 高度# lateral 横向有多少个网 ...

  8. Android按钮的各个样式设置

    安卓开发学习之014 Button应用详解(样式.背景.按钮单击.长按.双击.多击事件) 一.Button简介 按钮也是继承自TextView 二.XML定义方法 <Button android ...

  9. IOS UIButton用法详解

    这段代码动态的创建了一个UIButton,并且把相关常用的属性都列举了.希望对大家有用.   //这里创建一个圆角矩形的按钮UIButton *button1 = [UIButton buttonWi ...

  10. Android开发-动态布局小记

    android动态布局相比静态布局,动态布局不用再将xml转变了布局代码,提高了一定的效率,当然可以忽略不记.动态布局主要是比较灵活,可以很快的在代码中直接修改布局,并直接使用控件进行业务逻辑开发.但 ...