MySQL——分表,分库操作
2017-12-28 21:23
211 查看
说明
大数据量并且访问频繁的表,将其分为若干个表。如果不分的话,进行一次查询就会将表锁住,导致不能进行其他操作,故分表。表分割
垂直分割应用场景:热数据放一个表里,冷数据放一个表里。冷数据使用MyIsam 可以有更好的查询数据。活跃数据,可以使用Innodb ,可以有更好的更新速度。对于一些特殊的活跃数据,也可以考虑使用memcache ,redis之类的缓存,等累计到一定量再去更新数据库。垂直分割数据行数一样,但是表结构不一样,实现起来也简单。
水平分割应用场景:一个100万行数据的表,可以分成100个1万行数据的表,水平分割表的结构都一样的,数据的行数有可能不一样。
原理很简单
使用merge存储引擎实现水平分割
一般我们建表用的都是InnoDB引擎,在分表时就需要使用其他的。步骤:1.创建一个user1表,ENGINE=MyISAM。
2.创建一个结构相同的的user2表,ENGINE=MyISAM。
3.创建一个user表,ENGINE=MRG_MYISAM,并联合user1和user2
如果使用navicat工具的话,选择一下就好
对应的sql语句
//创建表user1 CREATE TABLE `user1` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(255) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=MyISAM AUTO_INCREMENT=1 DEFAULT CHARSET=utf8; //创建表user2 CREATE TABLE `user2` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(255) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=MyISAM AUTO_INCREMENT=1 DEFAULT CHARSET=utf8; //创建表user CREATE TABLE `user` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(255) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=MRG_MyISAM DEFAULT CHARSET=utf8 UNION=(`user1`,`user2`);
作用
user表作为只读的表,可以进行查询,并不妨碍我们对user1和user2进行查询操作
相关文章推荐
- mysql的 函数 group_concat , substring_index 的使用以及 分库分表操作
- mysql 的分库分表操作
- MySQL常用操作(上)
- mysql基础命令操作
- MySQL用户授权 操作 乐杨俊
- mysql时间操作
- 【Python】python操作mysql
- Go操作mysql Memcache Mongodb
- 用Python操作Mysql
- MySQL学习笔记 2:约束、修改数据表和操作数据表中的记录
- MySQL操作命令
- MySQL操作失误,如何恢复数据
- MySQL核心基础(二)之数据库基本操作
- Mysql实用之一:命令行操作
- Ubuntu15.10操作mysql5.6数据库
- mysql操作
- 最近看一个机器里面居然保存mysql管理员的操作命令
- CodeIgniter框架——创建一个简单的Web站点(include MySQL基本操作)
- 利用mysql的c api,在vs2010中操作mysql
- Asp.Net 2.0 操作mysql 数据基类(读取,删除,插入,更新)