MySQL Merge引擎实现分表
发表于:2024-11-23 作者:千家信息网编辑
千家信息网最后更新 2024年11月23日,Merge引擎是一组MyISAM表的组合,组合的分表结构必须完全相同,Merge表本身没有数据,对Merge表的操作实际上都是对子表的操作,只是对APP来说是透明的,在插入的时候默认是插入到最后一张表
千家信息网最后更新 2024年11月23日MySQL Merge引擎实现分表
Merge引擎是一组MyISAM表的组合,组合的分表结构必须完全相同,Merge表本身没有数据,对Merge表的操作实际上都是对子表的操作,只是对APP来说是透明的,在插入的时候默认是插入到最后一张表上,也可以指定插入到第一张表上,Merger表实际上只是多个子表的一个外壳,对它进行删除,不影响实际存储的数据。
创建子表user1
CREATE TABLE `user1` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(100) CHARACTER SET latin1 DEFAULT NULL, PRIMARY KEY (`id`)) ENGINE=MyISAM AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;
创建子表user2
CREATE TABLE `user2` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(100) CHARACTER SET latin1 DEFAULT NULL, PRIMARY KEY (`id`)) ENGINE=MyISAM AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;
创建Merge表alluser
CREATE TABLE `alluser` ( `id` int(11) NOT NULL, `name` varchar(100) DEFAULT NULL, PRIMARY KEY (`id`)) ENGINE=MRG_MyISAM DEFAULT CHARSET=latin1 INSERT_METHOD=LAST UNION=(`user1`,`user2`);
现在对alluser进行插入数据
然后查看user2表的数据发现已经插入进去
下一步对子表分表进行插入操作,然后查看alluser表
发现对子表的插入操作最后都会映射到alluser表中,从一定意义上实现了分表,但是也有局限性,就是数据分布不均匀,因为插入的时候不能自定义规则,只能插入创建时指定的子表,还有就没有约束条件的检查,例如在三张表中都设定id为主键,我们在user2中插入一条user1中已经存在的数据,但是alluser表并不报错且成功插入
由于这些原因,Merge引擎实现的分表在实际应用中并不多
数据
分表
实际
对子
引擎
只是
实际上
时候
建子
组合
相同
成功
原因
外壳
多个
就是
局限性
意义
条件
结构
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
创景网络技术
sql搭建数据库
千诚凤互联网科技
文件服务器分布式访问
炒股软件开发详细流程
开源数据库安全
直播软件软件开发
软件开发单位一般多少人
服务器里双芯片的显卡
软件开发后台一般拿多少钱
教育部文件中小学生网络安全
邀请对方入库我司人才数据库的函
重庆cisp网络安全培训
繁峙统计局网络安全
数据库基础105个举例
培训软件开发软件
移动服务器端口
图形中的数据库
医院什么软件开发
国家军事网络安全由谁另行规定
怀旧服20个服务器
网络安全法最新版全文
浙江华为服务器虚拟化操作服务器
视频会议软件开发售后服务方案
plc存储数据库
网络安全风险保险
网络安全思想防线堡垒坚实
新吴区进口网络技术创造辉煌
小米5无限重启 导出数据库
软件开发和dt