如何设计合理的多表关联的表分区

数据库 SQL Server
在前一篇《手把手教你建立SQL数据库的表分区》笔记中,我给大家讲述了如何建立表分区,但是没有阐述更深层次的问题,这里我补充一下,希望看帖的朋友踊跃讨论或者拍砖。

在前一篇《手把手教你建立SQL数据库的表分区》笔记中,我给大家讲述了如何建立表分区,但是没有阐述更深层次的问题,这里我补充一下,希望看帖的朋友踊跃讨论或者拍砖。

我们在日常的设计过程中,一个数据库往往有很多表,这些表之间存在着一定的关联。正是因为这些关联给如何实现一个高性能的分区带来了挑战。下面是设计多表之间存在关联的表的分区的三个重要原则:

1)相关联的两个或多个表,在建立分区的时候每个表***选择有相同数量的分区参数,而且参数的类型要相同。比如订单的主从表之间,如果主表选择了创建时间作为分区条件,那么从表也应该以时间字段来作为分区的条件。

2)选择相同个的分区数,比如主表进行了10个分区,那么从表也进行10个分区。一个表最多可进行1000个分区。

3)选择相同的分区临界值,比如从表选择了时间‘20100101’,那么从表也选择‘20100101’作为分区临界值。

满足上述三个条件,数据库引擎在对分区进行查询的时候会自动对各个分区按查询给定的条件进行分区连接,极大的提高了连接的效率。

补充:1)进行表分区的多个表必须位于同一个数据库中

2)当你纠结于表分区还是分区视图的时候,优先选择表分区

3)对于表上有索引的表进行分区,通常的做法是:先建立表分区,而后为表建立索引,这样数据会自动以表的分区函数和分区方案为索引建立分区。但是才创建的时候为索引指定了不同的分区方案或者指定了特定的文件组来存储索引的话,数据库将不会自动为索引建立分区。

4)更多的限制请参考:http://msdn.microsoft.com/zh-cn/library/ms187526.aspx

---存在即是合理---

【编辑推荐】

  1. 说说Top子句对查询计划的影响
  2. SQL Server复灾 你懂了吗?
  3. SQL Server管理 这些你懂吗?
  4. 用一句SQL解决SQL中断号问题
  5. 谈谈Java调用SQL Server分页存储过程
责任编辑:艾婧 来源: 沙滩蚂蚁的博客
相关推荐

2023-11-14 09:08:12

MySQL多表关联

2010-04-08 17:40:02

Oracle 多表关联

2024-04-01 08:00:00

MySQL关联设计数据库

2010-04-29 16:53:18

Oracle多表关联

2010-11-25 13:45:07

MySQL查询语句

2020-06-30 11:36:45

错误码合理开发

2009-09-25 10:22:35

Hibernate多表

2010-10-15 10:37:27

MySQL创建关联表

2024-01-23 09:57:50

MySQL数据库

2024-07-10 10:08:36

项目多表关联哈希

2021-09-02 18:36:35

SQLWhereOn

2010-11-29 14:24:06

Linux软件管理

2011-08-17 12:25:11

2010-09-01 14:07:33

DB2映射

2010-04-19 14:23:34

Oracle增加表分区

2009-10-14 14:22:36

综合布线系统

2015-05-18 09:54:39

2019-02-19 10:25:28

JVM性能工具

2009-03-18 08:59:28

throw异常Java

2021-04-19 08:16:38

Hive数据类型大数据技术
点赞
收藏

51CTO技术栈公众号