MySQL数据库实验--什么是垂直分割与水平分割?
概述
我们一般会对大数据量并且访问频繁的表,将其分为若干个表。如果不分的话,很有可能进行一次查询就会将表锁住,导致不能进行其他操作,这也是为什么分表的一个原因。
表分割
垂直分割应用场景:热数据放一个表里,冷数据放一个表里。
冷数据使用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`);

插入数据测试
1、插入数据
insert into user1 values(1,'a'); insert into user1 values(2,'b'); insert into user1 values(3,'c'); insert into user1 values(4,'d'); insert into user2 values(1,'a'); insert into user2 values(2,'b'); insert into user2 values(3,'c'); insert into user2 values(4,'d');

2、查看user表

只查询user表

可以看出user表作为只读的表,可以进行查询,并不妨碍我们对user1和user2进行查询操作。
相关推荐
-
MySQL 安装失败,提示Apply Security Settings 的处理办法
MySQL 安装失败,提示Apply Security Settings 的处理办法2025-04-20 01:54:57 -
MySQL事务隔离级别详解2025-04-20 01:44:01
-
一文说清nginx规则匹配(含案例分析)2025-04-20 01:10:02
-
运维服务篇:Nginx常用功能(rewrite重定向/location定位等)
运维服务篇:Nginx常用功能(rewrite重定向/location定位等)2025-04-20 00:55:25 -
php定义变量规则不能包含哪些字符?2025-04-20 00:27:24