描述

该语句用来根据一张源表更新一张目标表的数据,可以对目标表进行插入、更新或者删除。

格式

  1. MERGE [hint_options]
  2. INTO table_factor [opt_alias]
  3. USING table_factor [opt_alias]
  4. ON '(' expr ')'
  5. [merge_update_clause]
  6. [merge_insert_clause]
  7. merge_update_clause:
  8. WHEN MATCHED THEN UPDATE SET update_asgn_list [WHERE expr] [DELETE WHERE expr]
  9. merge_insert_clause:
  10. WHEN NOT MATCHED THEN INSERT opt_insert_columns VALUES '(' insert_vals ')' [WHERE expr]

参数解释

参数

描述

hint_options

指定 hint 选项

table_factor

指定源表和目标表的表名

ON expr

源表和目标表的连接条件

update_asgn_list

更新语句的赋值操作

WHERE expr

触发更新、删除或者插入操作时的需要满足的条件

示例

示例表和数据基于以下定义:

  1. create table t1 (c1 int, c2 int);
  2. create table t2 (c1 int, c2 int);
  3. insert into t1 values (0, 0);
  4. insert into t1 values (1, null);
  5. insert into t1 values (2, null);
  6. insert into t2 values (1, 1);
  7. insert into t2 values (2, 20);
  8. insert into t2 values (3, 3);
  9. insert into t2 values (4, 40);

根据 T2 的数据更新 T1 的数据,

  1. 如果 t1.c1 在 t2 中能够找到 c1 取值相同的行

  2. 如果 t1.c2 取值为空,那么使用 t2.c2 更新 t1.c2

  3. 如果更新之后,t1.c2 >= 0,那么删除这行

  4. 如果 t2.c1 在 t1 中找不到取值相同的行

  5. 将 t2 中的这行插入到 t1 中,且只插入满足 t2.c2 < 10 的行

  1. merge into t1 using t2 on (t1.c1 = t2.c1)
  2. when matched then update set c2 = t2.c2 where t1.c2 is null delete where t1.c2 >= 10
  3. when not matched then insert values (t2.c1, t2.c2) where t2.c2 < 10;
  4. Query OK, 3 rows affected (0.02 sec)
  5. select * from t1;
  6. +------+------+
  7. | C1 | C2 |
  8. +------+------+
  9. | 0 | 0 |
  10. | 1 | 1 |
  11. | 3 | 3 |
  12. +------+------+