首页 / MYSQL / MySQL分区_MySQL
MySQL分区_MySQL
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了MySQL分区_MySQL,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1924字,纯文字阅读大概需要3分钟。
内容图文
![MySQL分区_MySQL](/upload/InfoBanner/zyjiaocheng/579/959d984c7a404602b5926e4379d8d92a.jpg)
分区主要分为垂直分区和水平分区两种:
垂直分表将一个N1+N2个字段的表Tab拆分成N1字段的子表Tab1和(N2+1)字段的子表Tab2;
其中子表Tab2包含了关于子表Tab1的主键信息,否则两个表的关联关系就会丢失。
当然垂直分表会带来程序端SQL的修改,若是应用程序已经应用很长的一段时间,然后程序的升级将是耗时而且易出错的,即升级的代价将会很大。
水平分区技术将一个表拆成多个表,比较常用的方式是将表中的记录按照某种Hash算法进行拆分,
简单的拆分方法如取模方式。
同样,这种分区方法也必须对前端的应用程序中的SQL进行修改方可使用。
而且对于一个SQL,它可能会修改两个表,那么你必须得写成2个SQL语句从而可以完成一个逻辑的事务,使得程序的判断逻辑越来越复杂,这样也会导致程序的维护代价高,也就失去了采用数据库的优势。
因此,分区技术可以有力地避免如上的弊端,成为解决海量数据存储的有力方法。
SHOW VARIABLES命令来确定MySQL是否支持分区
show variables like "%partition%" ;
+-------------------+-------+
| Variable_name | Value |
+-------------------+-------+
| have_partitioning | YES |
+-------------------+-------+
MySQL 分区引擎在一个单独的层中运行,并且可以和任何这样的层进行相互作用
同一个分区表的所有分区必须使用同一个存储引擎
为某个分区表配置一个专门的存储引擎,必须且只能使用[STORAGE] ENGINE 选项。
[STORAGE] ENGINE必须列在用在CREATE TABLE语句中的其他任何分区选项之前
可以通过使用用来创建分区表的CREATE TABLE语句的PARTITION子句的DATA DIRECTORY(数据路径)和INDEX DIRECTORY(索引路径)选项,为每个分区的数据和索引指定特定的路径。
MAX_ROWS和MIN_ROWS选项可以用来设定最大和最小的行数,它们可以各自保存在每个分区里。
分区类型:
Range分区 | 基于属于一个给定连续区间的列值 |
List分区 | 基于列值匹配一个离散值集合中的某个值来进行选择 |
Hash分区 | 用户定义表达式的返回值来进行选的分区 |
Key分区 | KEY分区只支持计算一列或多列 |
分区总是在创建时就自动的顺序编号,且从0开始记录
当有一新行插入到一个分区表中时,就是使用这些分区编号来识别正确的分区
参考文献:
http://dev.mysql.com/doc/refman/5.1/zh/partitioning.html
内容总结
以上是互联网集市为您收集整理的MySQL分区_MySQL全部内容,希望文章能够帮你解决MySQL分区_MySQL所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。