在前一篇《手把手教你建立SQL数据库的表分区》笔记中,我给大家讲述了如何建立表分区,但是没有阐述更深层次的问题,这里我补充一下,希望看帖的朋友踊跃讨论或者拍砖。
我们在日常的设计过程中,一个数据库往往有很多表,这些表之间存在着一定的关联。正是因为这些关联给如何实现一个高性能的分区带来了挑战。下面是设计多表之间存在关联的表的分区的三个重要原则:
1)相关联的两个或多个表,在建立分区的时候每个表***选择有相同数量的分区参数,而且参数的类型要相同。比如订单的主从表之间,如果主表选择了创建时间作为分区条件,那么从表也应该以时间字段来作为分区的条件。
2)选择相同个的分区数,比如主表进行了10个分区,那么从表也进行10个分区。一个表最多可进行1000个分区。
3)选择相同的分区临界值,比如从表选择了时间‘20100101’,那么从表也选择‘20100101’作为分区临界值。
满足上述三个条件,数据库引擎在对分区进行查询的时候会自动对各个分区按查询给定的条件进行分区连接,极大的提高了连接的效率。
补充:1)进行表分区的多个表必须位于同一个数据库中
2)当你纠结于表分区还是分区视图的时候,优先选择表分区
3)对于表上有索引的表进行分区,通常的做法是:先建立表分区,而后为表建立索引,这样数据会自动以表的分区函数和分区方案为索引建立分区。但是才创建的时候为索引指定了不同的分区方案或者指定了特定的文件组来存储索引的话,数据库将不会自动为索引建立分区。
4)更多的限制请参考:http://msdn.microsoft.com/zh-cn/library/ms187526.aspx
---存在即是合理---
【编辑推荐】