質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

89.55%

同じ列構成のテーブルを比較し、追加もしくは差異があるデータに対して処理を行いたい

解決済

回答 4

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 212

ARATAITE

score 0

前提・実現したいこと

Oracle DBにて2つの同じ列を持つテーブルを比較し、追加もしくは差分がある場合、フラグを立てる処理を行いたい。
削除された場合を考慮する必要はなく、追加と差分は同じ動作としたい。

テーブル例

テーブルA

No Data_A Data_B Data_C FLAG
1 AAA AAA AAA 0
2 BBB ZZZ BBB 0
3 CCC CCC ZZZ 0
4 DDD DDD DDD 0

テーブルB

No Data_A Data_B Data_C FLAG
1 AAA AAA AAA 0
2 BBB BBB BBB 0
3 CCC CCC CCC 0

処理後のテーブルA

No Data_A Data_B Data_C FLAG
1 AAA AAA AAA 0
2 BBB ZZZ BBB 1
3 CCC CCC ZZZ 1
4 DDD DDD DDD 1
CREATE TABLE TableA(
No NUMBER(12) DEFAULT 0 NOT NULL,
primary key(No),
Data_A VARCHAR2(100),
Data_B VARCHAR2(100),
Data_C VARCHAR2(100),
FLAG VARCHAR2(1));

COMMENT ON COLUMN TableA.No IS '主キー';
COMMENT ON COLUMN TableA.Data_A IS 'データA';
COMMENT ON COLUMN TableA.Data_B IS 'データB';
COMMENT ON COLUMN TableA.Data_C IS 'データC';
COMMENT ON COLUMN TableA.FLAG IS 'フラグ(0 or 1)';

CREATE TABLE TableB(
No NUMBER(12) DEFAULT 0 NOT NULL,
primary key(No),
Data_A VARCHAR2(100),
Data_B VARCHAR2(100),
Data_C VARCHAR2(100),
FLAG VARCHAR2(1));

COMMENT ON COLUMN TableB.No IS '主キー';
COMMENT ON COLUMN TableB.Data_A IS 'データA';
COMMENT ON COLUMN TableB.Data_B IS 'データB';
COMMENT ON COLUMN TableB.Data_C IS 'データC';
COMMENT ON COLUMN TableB.FLAG IS 'フラグ(0 or 1)';

Insert into TableA VALUES('1','AAA','AAA','AAA','0');
Insert into TableA VALUES('2','BBB','ZZZ','BBB','0');
Insert into TableA VALUES('3','CCC','CCC','ZZZ','0');
Insert into TableA VALUES('4','DDD','DDD','DDD','0');

Insert into TableB VALUES('1','AAA','AAA','AAA','0');
Insert into TableB VALUES('2','BBB','BBB','BBB','0');
Insert into TableB VALUES('3','CCC','CCC','CCC','0');

試したこと

minusを用いることで差分と追加分を取得できることは分かるのですが、UPDATEと組み合わせた場合の処理がわからないためご教示お願いします。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • Orlofsky

    2020/01/28 11:08

    せめて、テーブル定義はCREATE TABLE で提示しては?

    キャンセル

回答 4

check解決した方法

0

ひとまず下記の2つのUpdateで希望通りの動作となったため解決とします。

--差分用
Update
    TableA A
Set flag = (
Select 1 From TableB B Where A.no = B.no AND (A.data_a <> B.data_a OR A.data_b <> B.data_b OR A.data_c <> B.data_c))
Where exists (Select 1 From TableB B Where A.no = B.no AND (A.data_a <> B.data_a OR A.data_b <> B.data_b OR A.data_c <> B.data_c));

--追加用
Update
    TableA
Set flag = 1
Where No in (Select No From TableA Minus Select No From TableB);

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

取得したものをEXISTSで条件句に指定すればUPDATEできるのでは?

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

SQL 入門 (DMLの基本形式:UPDATE)
※ビューを使った更新(インラインビューを使った更新) を参照
以下引用

UPDATE (
     SELECT
            DEPT_NO, USER_NAME
     FROM USER_MASTER
     WHERE  DEPT_NO = '1002'
) -- [ ビューの別名 ]
SET
    USER_NAME = USER_NAME || ' 氏',
    MODIFIED_ON = SYSDATE
 /*
 WHERE
    DEPT_NO = '1002'
 */

minusを用いることで差分と追加分を取得できることは分かる

上記部分をビューの部分で使用すれば良いことになります。

単純にテーブルBの有無だけでフラグセットするなら、サブクエリーを条件にするのが効率的だと思います。

update テーブルA set フラグ=1
where 主キー in (select 主キー from テーブルB)


追記

update TableA A set flg=1
where not exsis (
       Select 1 From TableB B 
       Where A.no = B.no 
         AND A.data_a = B.data_a 
         and A.data_b = B.data_b 
         and A.data_c = B.data_c
      )

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2020/01/28 14:21

    回答ありがとうございます。
    MINUSで差分を取得した後、TableAのNoと差分データのNoで紐づくTableAのFLAGに1をしたいのですが、下記ではダメでした。
    UPDATE (
    SELECT No,Data_A,Data_B,Data_C FROM TABLEA
    MINUS
    SELECT No,Data_A,Data_B,Data_C FROM TABLEB
    )TMP
    SET TableA.FLAG=1 WHERE TableA.No=TMP.No;

    キャンセル

  • 2020/01/28 14:30 編集

    駄目とは?シンタックスエラーじゃないですか?
    where条件のtableA.Noなどは参照できないのでエラーなります。
    where条件はビュー内に含めて下さい。

    目的を果たすには、回答の2番目のSQLで十分だと思います。

    キャンセル

  • 2020/01/28 16:43

    SQLは目下勉強中でどういった理由でエラーとなっているのかが分からず、曖昧なまま記載してしまいました。以後気を付けます。

    2番目のSQLではNo2,3,4ではなく、No1,2,3のフラグが立つため、目的通りの動作となりませんでした。

    キャンセル

  • 2020/01/28 18:53

    多分SQL1文で行けると思いますので、追記しておきます。

    キャンセル

0

MERGE を使っては?

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2020/01/28 13:00

    Insert要件はなさそうですが?

    キャンセル

  • 2020/01/28 13:36

    insertはしないでupdateだけ。

    キャンセル

  • 2020/01/28 14:27

    敢えてそのようなオーバーヘッドを持ち込まない方が良いと思うのですが。

    キャンセル

  • 2020/01/28 17:39

    なるほど。
    https://oraclesqlpuzzle.ninja-web.net/10-107.html の UpdatableViewでupdateした方が良いかも?

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 89.55%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる
  • トップ
  • SQLに関する質問
  • 同じ列構成のテーブルを比較し、追加もしくは差異があるデータに対して処理を行いたい