回答編集履歴

1

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

2018/06/13 03:26

投稿

nak
nak

スコア696

test CHANGED
@@ -18,8 +18,18 @@
18
18
 
19
19
  WHEN MATCHED THEN UPDATE SET t1.department = t2.department -- on句の条件にMATCHしたらUPDATE
20
20
 
21
- WHEN NOT MATCHED THEN INSERT VALUES (t2.name_id, t2.department) -- on句の条件にMATCHしなかったらUPDATE
21
+ WHEN NOT MATCHED THEN INSERT VALUES (t2.name_id, t2.department) -- on句の条件にMATCHしなかったらINSERT
22
22
 
23
23
  ;
24
24
 
25
25
  ```
26
+
27
+
28
+
29
+ (2018/06/13追記)
30
+
31
+ [chelsy7110](https://teratail.com/users/chelsy7110)さんの回答を拝見し、改めて `期待する結果(t1)` を見てみました。
32
+
33
+ t2にしか存在しないレコードをt1にINSERTする必要はなく、t1の既存レコードのdepartmentがUPDATEできれば良いのですね(すみません、質問を若干勘違いしておりました)。
34
+
35
+ その場合、上記コードの `WHEN NOT MATCHED ~` 以降を削除していただければ、期待した動作になるのではないかと思われます。