質問するログイン新規登録

回答編集履歴

1

サンプルコードのコメントが誤っていたので修正&他の方のご回答を受けてコメント追加

2018/06/13 03:26

投稿

nak
nak

スコア696

answer CHANGED
@@ -8,6 +8,11 @@
8
8
  MERGE INTO t1 USING t2
9
9
  ON t1.name_id = t2.name_id
10
10
  WHEN MATCHED THEN UPDATE SET t1.department = t2.department -- on句の条件にMATCHしたらUPDATE
11
- WHEN NOT MATCHED THEN INSERT VALUES (t2.name_id, t2.department) -- on句の条件にMATCHしなかったらUPDATE
11
+ WHEN NOT MATCHED THEN INSERT VALUES (t2.name_id, t2.department) -- on句の条件にMATCHしなかったらINSERT
12
12
  ;
13
- ```
13
+ ```
14
+
15
+ (2018/06/13追記)
16
+ [chelsy7110](https://teratail.com/users/chelsy7110)さんの回答を拝見し、改めて `期待する結果(t1)` を見てみました。
17
+ t2にしか存在しないレコードをt1にINSERTする必要はなく、t1の既存レコードのdepartmentがUPDATEできれば良いのですね(すみません、質問を若干勘違いしておりました)。
18
+ その場合、上記コードの `WHEN NOT MATCHED ~` 以降を削除していただければ、期待した動作になるのではないかと思われます。