[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
)