MYSQL的MERGE存储引擎

转载 2012年03月29日 17:29:25

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://blog.sina.com.cn/s/blog_753035050100wi4m.html

MySQL MERGE存储引擎 简介

MERGE存储引擎把一组MyISAM数据表当做一个逻辑单元来对待,让我们可以同时对他们进行查询。构成一个MERGE数据表结构的各成员MyISAM数据表必须具有完全一样的结构。每一个成员数据表的数据列必...

MySQL MERGE存储引擎 简

MySQL MERGE存储引擎
  • shmnh
  • shmnh
  • 2016年03月16日 00:16
  • 319

MySQL的表类型的(存储引擎)的选择MyISAM+InnoDB+MEMORY+MERGE

MySQL的表类型的(存储引擎)的选择MyISAM+InnoDB+MEMORY+MERGE
  • A784586
  • A784586
  • 2017年03月09日 19:32
  • 626

MySQL Merge存储引擎

MySQL Merge存储引擎

MySQL MERGE存储引擎 简介

MERGE存储引擎把一组MyISAM数据表当做一个逻辑单元来对待,让我们可以同时对他们进行查询。构成一个MERGE数据表结构的各成员MyISAM数据表必须具有完全一样的结构。每一个成员数据表的数据列必...

MySQL中merge表存储引擎用法

在Mysql数据库中,Merge表有点类似于视图。mysql的merge引擎类型允许你把许多结构相同的表合并为一个表。之后,你可以执行查询,从多个表返回的结果就像从一个表返回的结果一样。每一个合并的表...

使用Merge存储引擎实现 mysql分表

分表就是把N条记录的表,分成若干个分表,各个分表记录的总和仍为N。   分表的方法有很多,用merge来分表,是最简单的一种方式. Merge表的优点: A: 分离静态的和动态的数据 B:...

Mysql MERGE 存储引擎

MERGE 存储引擎进行合表操作

Mysql Merge存储引擎

Mysql Merge存储引擎。 CREATE TABLE t1 ( a INT NOT NULL AUTO_INCREMENT PRIMARY KEY, message CHAR(20)); CR...
  • cupder
  • cupder
  • 2015年11月03日 17:42
  • 143

MYSQL之 1)临时表的应用场景 2)分表后的merge存储引擎查询应用场景

实际工作用到的,放这里总结一下,容易健忘,mark一下:1)临时表:在网上搜索了一下,对比一下临时表和内存表: 临时表的表结构和数据都是储存在内存中的,session开始到结束是它的生命周期。 内存表...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:MYSQL的MERGE存储引擎
举报原因:
原因补充:

(最多只允许输入30个字)