您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

MYSQL的MERGE存储引擎_MySQL

2024/6/11 13:04:50发布22次查看
bitscn.com
mysql的merge存储引擎
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值。
bitscn.com
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product