如何设计合理的多表关联的表分区
2023-03-31 11:06:44 时间
在前一篇《手把手教你建立SQL数据库的表分区》笔记中,我给大家讲述了如何建立表分区,但是没有阐述更深层次的问题,这里我补充一下,希望看帖的朋友踊跃讨论或者拍砖。
我们在日常的设计过程中,一个数据库往往有很多表,这些表之间存在着一定的关联。正是因为这些关联给如何实现一个高性能的分区带来了挑战。下面是设计多表之间存在关联的表的分区的三个重要原则:
1)相关联的两个或多个表,在建立分区的时候每个表***选择有相同数量的分区参数,而且参数的类型要相同。比如订单的主从表之间,如果主表选择了创建时间作为分区条件,那么从表也应该以时间字段来作为分区的条件。
2)选择相同个的分区数,比如主表进行了10个分区,那么从表也进行10个分区。一个表最多可进行1000个分区。
3)选择相同的分区临界值,比如从表选择了时间‘20100101’,那么从表也选择‘20100101’作为分区临界值。
满足上述三个条件,数据库引擎在对分区进行查询的时候会自动对各个分区按查询给定的条件进行分区连接,极大的提高了连接的效率。
补充:1)进行表分区的多个表必须位于同一个数据库中
2)当你纠结于表分区还是分区视图的时候,优先选择表分区
3)对于表上有索引的表进行分区,通常的做法是:先建立表分区,而后为表建立索引,这样数据会自动以表的分区函数和分区方案为索引建立分区。但是才创建的时候为索引指定了不同的分区方案或者指定了特定的文件组来存储索引的话,数据库将不会自动为索引建立分区。
4)更多的限制请参考:http://msdn.microsoft.com/zh-cn/library/ms187526.aspx
---存在即是合理---
【编辑推荐】
相关文章
- Leetcode No.124 二叉树中的最大路径和
- sklearn中fit、fit_transform、transform的区别
- select 1 from dual
- Oracle数据库脚本中的set define off
- MySQL8.0 下载安装启动(Windows10)
- 数据泄露风险如何规避?聊一聊“公有云”安全 | FreeBuf甲方群讨论
- 程序员分库分表:入门必备
- 验证码去干扰线
- centos7 安装redis和配置的命令方法
- Spring认证中国教育管理中心-Spring Data MongoDB教程十三
- mysql事务隔离级别——读已提交
- 使用PHP脚本创建MySQL 数据表
- 使用 mysqladmin 删除数据库MySQL
- 复制MySQL的数据表的操作命令方式
- 启动及关闭 MySQL 服务器的命令操作方式
- MongoDB 创建数据库的格式语法
- MongoDB 删除文档的操作命令
- MongoDB 使用 find() 方法查询文档
- sqlite3 命令创建新的 SQLite 数据库方法
- SQLite 利用DROP TABLE 语句删除表的方式