忍者ブログ
JavaScript , Java , DOS , HTML(CSS) , JSP , SQL , VB , VBScript , ・・・etc などの覚書
×

[PR]上記の広告は3ヶ月以上新規記事投稿のないブログに表示されています。新しい記事を書く事で広告が消えます。

あるテーブルB にあり テーブルA にないレコードをインポートする方法

OracleではMergeがあるが、取り込むカラムがキーの場合使用出来ない。
よって、以下の方法で行う。

USH_PJTNO がテーブルBのキー及び取り込みたいカラム
CODE がUSH_PJTNOを取り込み先

案1
INSERT INTO テーブルB(USH_PJTNO)
SELECT CODE
 FROM テーブルA
 WHERE WSNO=0 AND TERM_END='4712/12/31' AND CODE LIKE 'PJT%'
MINUS
SELECT USH_PJTNO
 FROM A_WBSPRJ_UNIT

案2
INSERT INTO テーブルB(USH_PJTNO)
SELECT A.CODE FROM テーブルA A
 WHERE NOT EXISTS (
 SELECT B.USH_PJTNO FROM テーブルB B
  WHERE A.CODE = B.USH_PJTNO
 ) AND A.WSNO=0 AND A.TERM_END='4712/12/31' AND CODE LIKE 'PJT%'


******MERGE*(参考 以下の場合、USH_PJTNOがキーの場合エラーになる)********

MERGE INTO テーブルB T
     USING テーブルA F
     ON ( T.USH_PJTNO = F.CODE AND F.WSNO=0)
WHEN MATCHED THEN
             UPDATE SET
         T.USH_PJTNO = F.CODE,
WHEN NOT MATCHED THEN
      INSERT (
         USH_PJTNO
         )
      VALUES (
         F.CODE
         )

PR
ブログ内検索
カレンダー
03 2025/04 05
S M T W T F S
1 2 3 4 5
6 7 8 9 10 11 12
13 14 15 16 17 18 19
20 21 22 23 24 25 26
27 28 29 30

Copyright © [ moriBlog-memo ] All rights reserved.
Special Template : 忍者ブログ de テンプレート Special Thanks : 忍者ブログCommercial message : [PR]