Mysql中MERGE存储引擎的介绍(代码示例)
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存储引擎的介绍(代码示例)的细致内容,更多请关注 百分百源码网 其它相干文章!