zoukankan      html  css  js  c++  java
  • SQL Server表分区详解(转)

    原文链接:https://www.cnblogs.com/Fooo/archive/2011/01/25/1944395.html

    只有将数据分区分到不同的磁盘上,才会有较大的提升

    分区请三思

    1.虽然分区可以带来众多的好处,但是同进也增加了实现对象的管理费用和复杂性。因此在进行分区之前要首先仔细的考虑以确定是否应为对象进行分区。
    2.在确定了为对象进行分区后,下一步就要确定分区键和分区数。要确定分区数据,应先评估您的数据中是否存在逻辑分组和模式。
    3.确定是否应使用多个文件分组。为了有助于优化性能和维护,应使用文件组分离数据。文件组是数据库数据文件的逻辑组合,它可以对数据文件进行管理和分配,以便提高数据库文件的并发访问效率。 

    为了简化操作,SQL Server 2008中为表分区提供了相关的操作

       

     操作的顺序:
         1、先定义文件组
         2、指定哪些辅助数据库文件属于这个文件组
         3、将表放入到文件组中
     

    数据库分文件组(指定磁盘):

    数据实际上是依附于表来存在的,我们将表放入到文件组中,而文件组是一个逻辑的概念,其实体是辅助数据库文件(ndr),所以就等于将我们指定的数据放入到了指定的辅助数据库文件中,然后如果将这些辅助数据库文件放入在不同的磁盘分区中,就可以最终实现有针对性的对相应的数据实现性能的优化。

    创建文件组时, 定义不同的文件组名称, 可以有序地进行下一步表分区的分区映射文件组, 如上图(选择数据库,右键查看属性图).

     一个水平分区表中有多个分区,每个分区对应一个文件组,这样就产生了很多文件组,因此性能也会有所提升,包括I/O性能提升,因为所有分区可以驻扎在一个不同的磁盘上,另一个好处是可以通过备份文件组单独备份一个分区,此外,SQL Server数据库引擎可以智能判断哪个分区上存放了什么数据,如果不止一个分区被访问,那么还可以借助多处理器实现并行数据检索。这种设计也充分利用了分区表的优势。

    1,提高可伸缩性和可管理性:在SQL server 2005中建立分区, 改善大型表以及具有各种访问模式的表的可 伸缩性和可管理性。 
    2,提高性能, 
    3,只有将数据分区分到不同的磁盘上,才会有较大的提升。
    4. 因为在运行涉及表间联接的查询时,多个磁头可以同时读取数据

    对SQL Server数据表进行分区的过程分为三个步骤:

      1)建立分区函数

      2)建立分区方案

      3)对表格进行分区

    步骤如下:

  • 相关阅读:
    bzoj2957 -- 线段树
    bzoj2209 [ JSOI2011 ] -- splay
    bzoj3874 [ AHOI2014 ] -- 爬山算法
    bzoj1038 [ ZJOI2008 ] -- 模拟退火+二分
    bzoj2428 [ HAOI2006 ] -- 模拟退火
    bzoj3680 -- 模拟退火
    bzoj4500 -- 差分约束
    bzoj3527 -- FFT
    bzoj1013 [ JSOI2008 ] -- 高斯消元
    使用nginx try_files 指令 管理静态资源
  • 原文地址:https://www.cnblogs.com/wangdongying/p/12218088.html
Copyright © 2011-2022 走看看