MERGE 存储引擎把一组 MyISAM 数据表当作一个逻辑单位来看待,让我们能够同时对他们举行查询。组成一个 MERGE 数据表构造的各成员 MyISAM 数据表必需具有完整一样的表构造。每个成员数据表的数据列必需依据一样的递次定义一样的名字和范例,索引也必需依据一样的递次和一样的体式格局定义。假定你有几个日记数据表,他们内容分别是这几年来每一年的日记纪录项,他们的定义都是下面如许,YY 代表年份(引荐课程:MySQL教程)
CREATE TABLE log_YY ( dt DATETIME NOT NULL, info VARCHAR(100) NOT NULL, INDEX (dt) ) ENGINE = MyISAM;
假定日记数据表的当前鸠合包含 log_2004、log_2005、log_2006、log_2007 ,而你能够建立一个以下所示的 MERGE 数据表把他们归拢为一个逻辑单位:
CREATE TABLE log_merge ( dt DATETIME NOT NULL, info VARCHAR(100) NOT NULL, INDEX(dt) ) ENGINE = MERGE UNION = (log_2004, log_2005, log_2006, log_2007);
ENGINE 选项的值必需是 MERGE,UNION 选项列出了将被收录在这个 MERGE 数据表离得各有关数据表。把这个 MERGE 建立出来后,就能够像看待任何其他数据表那样查询它,只是每一次查询都将同时作用与组成它的每个成员数据表 。下面这个查询能够让我们晓得上述几个日记数据表的数据行的总数:
SELECT COUNT(*)FROM log_merge;
下面这个查询用来肯定在这几年里每一年各有若干日记纪录项:
SELECT YEAR(dt) AS y, COUNT(*) AS entries FROM log_merge GROUP BY y;
除了便于同时援用多个数据表而无需发出多条查询,MERGE 数据表还供应了以下一些方便。
1)、MERGE 数据表能够用来建立一个尺寸凌驾各个 MyISAM 数据表所许可的最大长度逻辑单位
2)、经由紧缩的数据表包含到 MERGE 数据内外。比如说,在某一年完毕以后,你应当不会再往响应的日记文件里增加纪录,所以你能够用 myisampack 东西紧缩它以节约空间,而 MERGE 数据表仍能够像平常那样事情
3)、MERGE 数据表也支撑 DELETE 和 UPDATE 操纵。INSERT 操纵比较贫苦,由于 MySQL 须要晓得应当把新数据行插进去到哪个成员内外去。在 MERGE 数据表的定义里能够包含一个 INSERT_METHOD 选项,这个选项的可取值是 NO、FIRST、LAST,他们的寄义依次是 INSERT操纵是被制止的、新数据行将被插进去到现在 UNION 选项里列出的第一个数据表或末了一个数据表。比如说,以下定义将对 log_merge 数据表的 INSERT 操纵被当刁难 log_2007 数据表----它是 UNION 选项所列出的末了一个数据表:
CREATE TABLE log_merge( dt DATETIME NOT NULL, info VARCHAR(100) NOT NULL, INDEX(dt) ) ENGINE = MERGE UNION = (log_2004, log_2005, log_2006, log_2007) INSERT_METHOD = LAST;
建立一个新的成员数据表 log_2009 并让他有一样的表构造,然后修正 log_merge 数据表把 log_2009 包含进来:log_2009:
CREATE TABLE log_2009 LIKE log_2008; //依据旧表建立新表 ALTER TABLE log_merge UNION = (log_2004, log_2005, log_2006,log_2007,log_2008,log_2009);
以上就是Mysql中MERGE存储引擎的引见(代码示例)的细致内容,更多请关注ki4网别的相干文章!