回答編集履歴
1
サンプルコードのコメントが誤っていたので修正&他の方のご回答を受けてコメント追加
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しなかったら
|
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 ~` 以降を削除していただければ、期待した動作になるのではないかと思われます。
|