MySQL Merge引擎实现分表
发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,Merge引擎是一组MyISAM表的组合,组合的分表结构必须完全相同,Merge表本身没有数据,对Merge表的操作实际上都是对子表的操作,只是对APP来说是透明的,在插入的时候默认是插入到最后一张表
千家信息网最后更新 2025年11月07日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安全错误
数据库的锁怎样保障安全
北京有信网络技术
云蹦迪软件开发
服务器制作绩效考核
服务器文件泄露原理
易语言读取数据库多好慢
农村小学网络安全教育
河北党建设计软件开发
硬盘放数据库
公共厕所效果图软件开发
数据库为什么要创建触发器
java软件开发专业怎么样
传输网络安全性保障措施
串口服务器的工作位置
济宁软件开发哪家靠谱
TBC怀旧服服务器碧空之歌
云南linux软件开发
服务器管理怎样可以快速
江苏特种网络技术服务标准
网络安全比赛小说
网络安全监测胎心男女
描述一下软件开发过程
derby数据库部署
计算机软件开发技术职业通道
下列属于网络安全法律
互联网科技的市场分析
火鸟数据库安装
学软件开发好还是会计好
电脑上可以安装2个数据库吗
璧刃科技软件开发
软件开发外包咨询