mysql merge oracle_Mysql Merge表 – 提供7*24专业数据库(Oracle,SQL Server,MySQL等)恢复和Oracle技术服务@Tel:+86 1342964...

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

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

创建方法如下:

mysql> create table t1(id int not null primary key,name varchar(20)) engine=myisam;

Query OK, 0 rows affected (0.03 sec)

mysql> create table t2(id int not null primary key,name varchar(20)) engine=myisam;

Query OK, 0 rows affected (0.00 sec)

mysql> create table mrg(id int not null primary key,name varchar(20)) engine=merge union(t1,t2) insert_method=first;

Query OK, 0 rows affected (0.00 sec)

测试:

1、在t1中插入数据

mysql> insert into t1 values(1,’tttttt’);

Query OK, 1 row affected (0.03 sec)

mysql> insert into t1 values(2,’tttttt’);

Query OK, 1 row affected (0.00 sec)

2、查询t1表

mysql> select * from t1;

+—-+——–+

| id | name |

+—-+——–+

| 1 | tttttt |

| 2 | tttttt |

+—-+——–+

2 rows in set (0.00 sec)

3、查询mrg表

mysql> select * from mrg;

+—-+——–+

| id | name |

+—-+——–+

| 1 | tttttt |

| 2 | tttttt |

+—-+——–+

2 rows in set (0.00 sec)

4、在t2中插入数据

mysql> insert into t2 values(1,’ssssss’);

Query OK, 1 row affected (0.00 sec)

5、查询t2表

mysql> select * from t2;

+—-+——–+

| id | name |

+—-+——–+

| 1 | ssssss |

+—-+——–+

1 row in set (0.00 sec)

6、查询mrg表

mysql> select * from mrg;

+—-+——–+

| id | name |

+—-+——–+

| 1 | tttttt |

| 2 | tttttt |

| 1 | ssssss |

+—-+——–+

3 rows in set (0.00 sec)

7、mrg表中插入数据并测试

mysql> insert into mrg values(1,’ssssss’);

ERROR 1062 (23000): Duplicate entry ’1′ for key ‘PRIMARY’

mysql> insert into mrg values(2,’ssssss’);

ERROR 1062 (23000): Duplicate entry ’2′ for key ‘PRIMARY’

mysql> insert into mrg values(3,’ssssss’);

Query OK, 1 row affected (0.00 sec)

mysql> insert into t2 values(4,’ssssss’);

Query OK, 1 row affected (0.00 sec)

mysql> insert into mrg values(4,’ssssss’);

Query OK, 1 row affected (0.00 sec)

mysql> select * from t1;

+—-+——–+

| id | name |

+—-+——–+

| 1 | tttttt |

| 2 | tttttt |

| 3 | ssssss |

| 4 | ssssss |

说明:因为我们设置的 INSERT_METHOD为FIRST,因此插入数据进入t1表,而t1表中有主键,所以部分数据插入失败

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值。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值