博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MYSQL的MERGE存储引擎
阅读量:1985 次
发布时间:2019-04-27

本文共 1181 字,大约阅读时间需要 3 分钟。

MYSQL的引擎不是一般的多,这次说到的是MERGE,这个引擎有很多特殊的地方:

MERGE引擎类型允许你把许多结构相同的表合并为一个表。然后,你可以执行查询,从多个表返回的结果就像从一个表返回的结果一样。每一个合并的表必须有同样的表定义。

MERGE存储引擎在下面这种使用场合会最为有用,如果需要把日志纪录不停的录入MySQL数据库,并且每天、每周或者每个月都创建一个单一的表,而且要制作来自多个表的合计查询,MERGE表这时会非常有效。然而,这项功能有局限性。你只能合并MyISAM表而且必须严格遵守相同的表定义的限制。虽然这看起来好像是一个大问题,但是,如果你使用另外一种表类型(例如InnoDB),这种合并可能就不需要了。

其创建方法如下:

他将多个表在逻辑上当作一个表来查询。他建立后有两个文件, 

.frm 表结构定义 
.mrg union表的名字清单

两个基本表: 

CREATE TABLE TEST_MERGE_1( 
ID INT(5) NOT NULL, 
VALUE VARCHAR(100) NOT NULL, 
PRIMARY KEY(ID) 
) ENGINE=MyISAM DEFAULT CHARSET=utf8 
CREATE TABLE TEST_MERGE_2( 
ID INT(5) NOT NULL, 
VALUE VARCHAR(100) NOT NULL, 
PRIMARY KEY(ID) 
) ENGINE=MyISAM DEFAULT CHARSET=utf8

MERGE表的建立: 

CREATE TABLE TEST_MERGE( 
ID INT(5) NOT NULL, 
VALUE VARCHAR(100) NOT NULL, 
PRIMARY KEY(ID) 
) ENGINE=MRG_MyISAM DEFAULT CHARSET=utf8 INSERT_METHOD=LAST UNION=(TEST_MERGE_1,TEST_MERGE_2) ;

1. 此表类似于SQL中的union机制。 
2. 此表结构必须与基本表完全一致,包括列名、顺序。UNION表必须同属一个DATABASE。 
3. 基本表类型必须是MyISAM。 
4. 可以通过修改.mrg文件来修改MERGE表,每个基本表的名字占一行。注意:修改后要通过FLUSH TABLES刷新表缓存。 
5. 对基本表的更改可以直接反映在此表上。 
6. INSERT_METHOD的取值可以是: 0 不允许插入 FIRST 插入到UNION中的第一个表 LAST 插入到UNION中的最后一个表。(4.0之后可用) 
7. 定义在它上面的约束没有任何作用,约束是由基本表控制的,例如两个基本表中存在着同样的一个Key值,那么在MERGE表中会有两个一样的Key值。

 

原文:

转载地址:http://huzvf.baihongyu.com/

你可能感兴趣的文章
POJ-3304 Segments(计算几何)
查看>>
UVA-11538 Chess Queen(数学)
查看>>
UVA-11401 Triangle Counting(数学优化)
查看>>
Codeforces Round #369 (Div. 2)
查看>>
UVA 11426 GCD - Extreme (II)(欧拉函数)
查看>>
HDU-2838 Cow Sorting(树状数组)
查看>>
POJ-2299 Ultra-QuickSort(树状数组)(离散化)
查看>>
POJ-3107 Godfather & POJ-2378 Tree Cutting(树的重心)
查看>>
基于SSM的兼职论坛系统的设计与实现
查看>>
基于java的图书管理系统的设计与实现
查看>>
基于java的SSM框架理财管理系统的设计与实现
查看>>
基于java的ssm框架就业信息管理系统的设计
查看>>
基于java的ssm框架的旅游网站设计与实现
查看>>
基于java的SSM框架的流浪猫救助网站的设计与实现
查看>>
基于java的SSM框架的教务关系系统的设计与实现
查看>>
别再问我什么是A/B测试了!
查看>>
如何用同期群分析模型提升留存?(Tableau实战)
查看>>
爱了,吹爆这个高颜值的流程图工具!
查看>>
一个数据项目
查看>>
基于JAVA_JSP电子书下载系统
查看>>