mysql 分表原理_MYSQL 分表原理(转)
简介:
引用MySQL官方文档中的一段话:MERGE存储引擎,也被认识为MRG_MyISAM引擎,是一个相同的可以被当作一个来用的MyISAM表的集合."相同"意味着所有表同样的列和索引信息.你不能合并列被以不同顺序列于其中的表,没有恰好同样列的表,或有不同顺序索引的表.而且,任何或者所有的表可以用myisampack来压缩.
例子:
mysql>
show
engines;
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
|
Engine | Support | Comment
| Transactions | XA | Savepoints
|
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
|
MEMORY | YES | Hash
based, stored in memory, useful for temporary tables | NO
| NO | NO
|
| MRG_MYISAM | YES |
Collection of identical MyISAM tables
| NO
| NO | NO |
| MyISAM
| YES | MyISAM storage
engine
| NO
| NO | NO
|
| BLACKHOLE | YES
| /dev/null storage engine (anything you write to it disappears) | NO
| NO | NO
|
| CSV |
YES | CSV storage engine
| NO | NO
| NO |
| PERFORMANCE_SCHEMA |
YES | Performance Schema
| NO | NO
| NO |
| ARCHIVE
| YES | Archive storage engine
| NO
| NO | NO
|
| FEDERATED | NO
| Federated MySQL storage engine
|
NULL | NULL | NULL
|
| InnoDB | DEFAULT |
Supports transactions, row-level locking, and foreign keys | YES
| YES | YES
|
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
9
rows in set (0.00 sec)
mysql> create table test1 (id int
not null auto_increment,name varchar(10) default null ,primary key (id))
engine=myisam auto_increment=1;
Query OK, 0 rows affected (0.01
sec)
mysql> create table test2 (id int not null
auto_increment,name varchar(10) default null ,primary key (id)) engine=myisam
auto_increment=1;
Query OK, 0 rows affected (0.00
sec)
mysql> INSERT INTO `test1` (`name`)
VALUES(‘beijing1‘);
Query OK, 1 row affected (0.00
sec)
mysql> INSERT INTO `test2` (`name`)
VALUES(‘beijing2‘);
Query OK, 1 row affected (0.00
sec)
mysql> create table test (id int not null
auto_increment,name varchar(10) default null ,index(id)) engine=mrg_myisam
union=(test1,test2) insert_method=last auto_increment=1;
Query
OK, 0 rows affected (0.03 sec)
mysql> select id,name from
test;
+----+----------+
| id | name
|
+----+----------+
| 1 |
beijing1 |
| 1 | beijing2
|
+----+----------+
2 rows in set (0.00
sec)
mysql> INSERT INTO `test` (`name`)
VALUES(‘beijing3‘);
Query OK, 1 row affected (0.00
sec)
mysql> select id,name from test;
+----+----------+
| id | name
|
+----+----------+
| 1 | beijing1
|
| 1 | beijing2 |
| 2 | beijing3
|
+----+----------+
3 rows in set (0.00
sec)
mysql> select id, name from test2
->
;
+----+----------+
| id | name
|
+----+----------+
| 1 | beijing2
|
| 2 | beijing3
|
+----+----------+
2 rows in set (0.00
sec)
mysql> system ls -l
/mysql/data/test
total 164
-rw-rw---- 1 mysql
mysql 8586 Feb 2 16:40 test1.frm
-rw-rw---- 1 mysql
mysql 20 Feb 2 16:40 test1.MYD
-rw-rw---- 1
mysql mysql 2048 Feb 2 16:40 test1.MYI
-rw-rw---- 1
mysql mysql 8586 Feb 2 16:40 test2.frm
-rw-rw---- 1
mysql mysql 40 Feb 2 16:44
test2.MYD
-rw-rw---- 1 mysql mysql 2048 Feb 2 16:44
test2.MYI
-rw-rw---- 1 mysql mysql 8586 Feb 2 16:43
test.frm
-rw-rw---- 1 mysql mysql 32 Feb 2
16:43
test.MRG
在这里需要注意建立MRG_MYISAM需要必须指定一个UNION=(list-of-tables)子句,它说明你要把哪些表当作一个表来用.另外一个重要的参数INSERT_METHOD,此参数INSERT_METHOD
= NO 表示该表不能做任何写入操作只作为查询使用,INSERT_METHOD =
LAST表示插入到最后的一张表里面.
例子:
mysql> show create
table test\G
*************************** 1. row
***************************
Table:
test
Create Table: CREATE TABLE `test` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(10)
DEFAULT NULL,
KEY `id` (`id`)
)
ENGINE=MRG_MyISAM DEFAULT CHARSET=utf8 INSERT_METHOD=LAST
UNION=(`test1`,`test2`)
1 row in set (0.00
sec)
mysql> CREATE TABLE `test` (`id` int(11) NOT NULL
AUTO_INCREMENT,`name` varchar(10) DEFAULT NULL,KEY `id` (`id`))ENGINE=MRG_MyISAM
DEFAULT CHARSET=utf8 INSERT_METHOD=NO UNION=(`test1`,`test2`);
Query OK, 0 rows affected
(0.00 sec)
mysql> select * from
test;
+----+----------+
| id | name
|
+----+----------+
| 1 | beijing1
|
| 1 | beijing2 |
| 2 | beijing3
|
+----+----------+
3 rows in set (0.00
sec)
mysql> INSERT INTO `test` (`name`)
VALUES(‘beijing4‘);
ERROR 1036 (HY000): Table ‘test‘ is read
only
当你需要在现有MRG_MYISAM添加新表的时候可以这样做
mysql>
create table test3 (id int not null auto_increment,name varchar(10) default null
,primary key (id)) engine=myisam auto_increment=1;
Query
OK, 0 rows affected (0.02 sec)
mysql> alter table test
engine=mrg_myisam union=(test1,test2,test3 ) insert_method=last;
Query OK, 0 rows affected
(0.01 sec)
Records: 0 Duplicates: 0 Warnings:
0
mysql> select * from
test;
+----+----------+
| id | name
|
+----+----------+
| 1 | beijing1
|
| 1 | beijing2 |
| 2 | beijing3
|
+----+----------+
3 rows in set (0.00
sec)
mysql> INSERT INTO `test` (`name`)
VALUES(‘beijing4‘);
Query OK, 1 row affected (0.00
sec)
mysql> select * from test;
+----+----------+
| id | name
|
+----+----------+
| 1 | beijing1
|
| 1 | beijing2 |
| 2 | beijing3
|
| 3 | beijing4
|
+----+----------+
4 rows in set (0.00
sec)
mysql> select * from test3;
+----+----------+
| id | name
|
+----+----------+
| 3 |
beijing4 |
+----+----------+
1 row in set (0.00
sec)
OK,完成了.
对于日常来说MRG_MYISAM分表优点主要有以下几点:
(1)对于日志类应用的表.比如,你可以把每月的数据放进分离的表中,用myisampack压缩这些表,创建一个MERGE表来把它们当作一个表来使用非常方便快捷.
(2)在查询速度上应该更优,对于一些表可以分割大的只读表,放进不同磁盘上的单个表中.基于这个建立一个MERGE表会比单纯一个大表速度应该会快不少.
(3)超过操作系统的文件尺寸限制,每个MyISAM表都受制于这个限制,但是MRG_MYSIAM则不会.
缺点:
MRG_MYISAM不支持全文索引还有其它一些MyISAM功能,当然可以在底表创建,但是仍然不能利用全文索引在MRG表上搜索.建立全文会报如下错误
ERROR
1214 (HY000): The used table type doesn‘t support FULLTEXT indexes
相关文章:

popStar手机游戏机机对战程序
DFS算,五分钟如果答案没有更新,那个解一般来说就很优了。 #include <cstdio> #include <iostream> #include <string.h> #include <cstdlib> #include <algorithm> #include <queue> #include <vector> #incl…

ps aux参数说明
运行 ps aux 的到如下信息: ps auxUSER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMANDsmmsp 3521 0.0 0.7 6556 1616 ? Ss 20:40 0:00 sendmail: Queue runner01:00:00 froot 3532 0.0 0.2 2428 …

myeclipse使用maven整合ssh配置
最近写项目,由于公司需求,使用myeclispe来开发maven项目,关于maven就不再介绍,无论是jar包管理功能,还是作为版本构建工具,优点自然是很多,下面先贴出所需要的配置文件。 maven所需要的 pom.xml 1 <proj…

C语言 #ifndef 引起的redefinition of xxx 问题解决
问题如下 多个.c和.h文件 其中cloth.h分布被hat.h和paths.h包含,编译时出现如下问题: error: redefinition of struct _Cloth 我的cloth.h定义如下: #include <stdio.h> #include <stdlib.h> #include "retval.h"…

mysql如何下载连接到visual_Visual Studio 2015 Community连接到Mysql
Visual Studio 2015 Community连接到MySQL,步骤很简单,但刚弄的时候一脸懵,现在记录如下以作备忘:安装好VS2015和Mysql后,只需要再安装两个东西即可。一个是SDK:MySQL for Visual Studio另一个是驱动&#…

web.py下获取get参数
比较简单,就直接上代码了: import web urls (/, hello ) app web.application(urls, globals()) class hello: def GET(self):print web.input()return "GET hello world"def POST(self):print web.input()return "POST hello w…

ORACLE 体系结构知识总结
ORACLE 体系结构.Oracle 体系结构图:.1.ORACLE 实例.1.1. Oracle 实例Oracle实例包括内存结构和后台进程System Global Area(SGA) 和Background Process 称为数据库实例文件。.2. Oracle 数据库一系列物理文件的集合(数据文件,控制文件&#…

余额宝技术架构读后感
本次阅读文章为:余额宝技术架构及演讲 文章地址:https://mp.weixin.qq.com/s?__bizMzAwMDU1MTE1OQ&mid2653547540&idx1&snb3f568ba4bd1c4a0a2d35c0e5ef033cc&scene21#wechat_redirect 通过阅读“余额宝技术架构及演讲”,了解…

网络故障排查命令
ping #检测目标主机是否畅通traceroute #追踪路由mtr #检查到目标主机之间是否有数据包丢失nslookup #查看域名并解析,获取IP地址telnet #检查端口链接状态tcpdump #细致分析数据包发送接收 的详细内容netstat #查看网络端口连接状态ss #另外一种各式的查看网络端口…

Java程序猿面试题集(181- 199)
Java面试题集(181-199) 摘要:这部分是包括了Java高级玩法的一些专题,对面试者和新入职的Java程序猿相信都会有帮助的。 181. 182. 183. 184. 185. 186. 187. 188. 189. 190. 191. 192. 193. 194. 195. 196. 197. 198. 199. 转载于…

mysql四维数组_MySQL如何实现数组功能
前段时间想要用数组功能实现某些需求,结果发现mysql不支持数组,这个确实让人很头痛。查阅官方文档,也没有这一方面的资料。结果在网上,看到了某仁兄贴出了变相实现的一种方法,代码如下:DELIMITER ;DROP DAT…

在iOS上使用ffmpeg播放视频
国外靠谱的有这几个:1、Mooncatventures group https://github.com/mooncatventures-group2、KxMoviePlayer (use OpenGLES, Core Audio) https://github.com/kolyvan/kxmovie3、FFmpeg for ios (with OpenGLES, AudioQueue) https://github.com/flyhawk007/FFmpeg-…

shell --- trap 抓取信号
1. 解决问题 针对部分运行在生产环境中的脚本来说,有一些脚本运行的过程是不能被中断的,比如:生产环境 定期备份脚本,为了保证备份安全,备份期间不能被 SIGTERM和SIGINT 之类的中断信号中断。 该种类型的脚本逻辑增加…

python运行错误怎么查找_求助,python的二分法查找,按照视频上的代码写下来,结果运行错误...
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼def bsearch(s,e,first,last,calls):print(first,last,calls)if (last-first) < 2: return s[first] e or s[last]mid first (last - first)/2if s[mid] e: return Trueif s[mid] > e: return bsearch(s,e,first,mid-1,c…

system.out 汉字乱码
使用sts时,文件编码都设置成了UTF-8,使用system.out.println输出汉字时,出现乱码。 解决方案: run>run configurations>common>encoding修改为gbk就可以了。转载于:https://www.cnblogs.com/javaleon/p/4075341.html

三阶段day1
1、动态网页 和 静态网页动态网页:数据可以进行交互 动态改变数据2、nodenode是基于chrome的V8引擎的Javscript运行环境node中的事件机制以及非阻塞式的I/O式模型 使其轻量又高效node中的npm 是全球最大的包管理器 (全球最大的垃圾网站)I:inp…

Oracle 12c DG备库Alert报错ORA-01110
环境是12.2.0.1 version, Oracle Data Guard备库近段时间一直报错,但是备库主库同步一致,数据一致。2019-03-06T23:42:22.18404808:00 Errors in file /u01/app/oracle/diag/rdbms/ccdb/ccdb/trace/ccdb_m000_129832.trc: ORA-01110: data file 7: /u01/…

linux的 计划任务机制,自己带节奏
文章目录1. 解决问题2. 计划任务分类3. 一次性计划任务实现添加计划步骤注意事项4. 周期性计划任务实现cron和crontab命令5. 延时计划任务6. flock脚本加锁,保证单实例运行1. 解决问题 环境中有脚本需求,周期性运行或者固定时间运行脚本,为了…

erlang的tcp服务器模板
改来改去,最后放github了,贴的也累,蛋疼 还有一个tcp批量客户端的,也一起了 大概思路是 混合模式 使用erlang:send_after添加recv的超时处理 send在socket的option里面可以设置超时 accept,connect都可以在调用的时候传…

react select默认选项_reactjs – 如何为Picker提供默认的“Please select …”选项?
我想让我的Picker在启动时显示“默认选项”.这意味着:像“请选择一个选项”之类的东西.我试图用这个短语手动添加一个选项,但是,这样在选择其他选项后可以重新选择“默认选项”,就像它是真正的选项之一.有一些方法可以做到这一点?selectedValue{this.sta…

Git创建本地分支并关联远程分支
创建本地分支git branch 分支名 例如:git branch dev,这条命令是基于当前分支创建的本地分支,假设当前分支是master(远程分支),则是基于master分支创建的本地分支dev。 切换到本地分支git checkout 分支名 例如:git ch…

shell --- awk规范 系统总结
文章目录awk和sed的区别awk脚本的流程控制awk 记录和字段字段的引用awk表达式赋值操作符算数操作符系统变量(awk本身自定义的系统变量)关系操作符布尔操作符awk 条件和循环条件语句循环awk 的数组数组的定义数组的遍历删除数组举例,编写awk脚…

java初始化实例化_Java对象的创建过程:类的初始化与实例化
一、Java对象创建时机我们知道,一个对象在可以被使用之前必须要被正确地实例化。在Java代码中,有很多行为可以引起对象的创建,最为直观的一种就是使用new关键字来调用一个类的构造函数显式地创建对象,这种方式在Java规范中被称为 …

CakePHP中出现persistent is not writable等Warning的解决方法
在新部署CakePHP项目或者从SVN中重新Update项目的时候,有时候会出现下面的警告: Warning (512): D:\xampp\htdocs\xxxx\app\tmp\cache\ is not writable [CORE\cake\libs\cache\file.php, line 281] Warning (512): \persistent\ is not writable [CORE\…

MySQL5.5加主键锁读问题
背景有同学讨论到MySQL 5.5下给大表加主键时会锁住读的问题,怀疑与fast index creation有关,这里简单说明下。对照现象为了说明这个问题的原因,有兴趣的同学可以做对比实验。1) 在给InnoDB表创建主键期间,会锁住该表上的读数据2)…

ansible之playbook
关键字 关键字 关键字 关键字 关键字 关键字转载于:https://www.cnblogs.com/shui-mo/p/10482375.html

设计模式 之美 -- 工厂方法模式
文章目录1. 解决问题2. 应用场景3. 实现如下C实现C语言实现4. 缺点1. 解决问题 在简单工厂模式中,我们使用卖衣服进行举例,同一种工厂可以卖很多不同种类的衣服,工厂只是将衣服的生产过程进行了封装。 当我们增加衣服种类的时候,…

java shiro实例_Apache Shiro入门实例
Shiro是一个强大灵活的开源安全框架,提供身份验证、授权、会话管理、密码体系。1.先创建一个Maven项目2.配置pomhttp://maven.apache.org/xsd/maven-4.0.0.xsd">4.0.0cn.edu.stushiro-test0.0.1-SNAPSHOTorg.apache.shiroshiro-core1.3.0org.slf4jslf4j-log…

采购申请-MRP
1、手工建立采购申请: ME51N 申请单建立的时候,在不知道给哪个部门使用的时候可以在科目指派中选择U 分配并处理采购申请:me57 A:首先分配供应商 B:在转换成PO 点自动分配-》点分配-》点处理分配完成PR转变成PO 2、MRP 首先要建立BOM,然后在建…

【C语言】07-预处理指令;-宏定义
预处理指令简介; 1,C在对源程序进行编译之前,会对一些特殊的预处理指令作解释,产生一个新的源程序,此过程叫做编译预处理.C在经过编译预处理之后才对新的源码进行通常的编译; 2,预处理以‘#’开头,且结尾不用分号,(用于和一般的C语句区分开来). 3,预处理指令可以出现在出现的任…