環境
oracle 11g
いつも大変助かっており、お世話になっております。
【テーブル1】
No、ID、大分類、中分類、小分類
1、001、10、0、0
2、001、10、10、0
3、001、10、20、0
4、002、20、30、40
【テーブル2】
No、ID、大分類、中分類、小分類、値
1、001、10、0、0、50
2、001、10、10、0、55
3、002、20、0、0、100
4、002、20、30、0、100
上記のデータあるとします。
select テーブル2.値 from
テーブル1
テーブル2 leftjoin on テーブル1.ID = テーブル2.ID
where テーブル1.大分類 = テーブル2.大分類
and テーブル1.中分類 = テーブル2.中分類
and テーブル1.小分類 = テーブル2.小分類
上記SQLでは、テーブル2.値は、No1の50とNo2の55が取得されます。
これを、
テーブル1のNo3で、
テーブル2のどれにも当て嵌まらない場合、
テーブル1.大分類を10として、テーブル2のNo1の値を取得したいのです。
また、テーブル1のNo4に関しては、
テーブル2のNo4を取得したいのです。
PL/SQL等、プログラムを組まないと取得出来ないものでしょうか?
SQLで取得できるテクニックをご享受頂きたいです。
どうぞ宜しくお願い致します。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Access(アクセス) access フォーム 大分類、小分類 1 2022/08/11 18:03
- Oracle SQL update方法 2 2022/06/22 14:07
- Oracle 下記のsqlで取得されるレコード以外を取得する方法ありますでしょうか。 SELECT B.番号, B 2 2022/04/20 23:21
- Oracle sqlで質問です。 aテーブルとbテーブルがあり、下記のsqlで取得したidとnameに一致しないレ 1 2022/04/20 20:34
- SQL Server DBのテーブルの設計ができず困っています。 2 2023/06/29 16:43
- Oracle SQLの書き方について 1 2023/04/13 09:54
- PostgreSQL PostgreSQL レコードからアイテム種類数を取得したい 2 2022/11/23 22:31
- Oracle sqlで質問です。 idを元にidに紐付くデータで住所コードがjpのみのデータ以外のidを取得したい 4 2023/03/20 17:41
- Oracle 質問です。 下記のテーブルとデータがあり、 取得想定結果のように出力したいです。 下記のsqlだと0 2 2023/05/23 19:10
- Oracle sqlで質問です。 Aテーブルの登録番号をキーにBテーブルから確認番号を取得したいのですが、Bテーブ 4 2023/05/18 13:08
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
update文で改行を入れる
-
ROWNUMでUPDATEをしたいのです...
-
テーブル名をカラムとして取得...
-
SQL、2つのテーブルで条件一致...
-
sqlplusで表示が変なので、出力...
-
SQL 複数テーブルのupdate
-
SQL*LoaderでCSVから指定した列...
-
SQLでSUMなどの関数でデータが...
-
特定のカラムが更新されたとき...
-
OracleのSQLで同テーブルのカラ...
-
LONG型の先頭250バイトを Varch...
-
ワークテーブルって何?
-
UPDATE文
-
数値をNUMBER型にするかCHAR型...
-
SQL文のCOUNTの戻り値は?
-
Viewのカラムの長さが不明?
-
distinct をexistsに変換する
-
カラム位置変更
-
SQL(oracle)でご助言いただきた...
-
CopyToClipboardからEXCELへPaste
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
テーブル名をカラムとして取得...
-
SQL、2つのテーブルで条件一致...
-
update文で改行を入れる
-
ROWNUMでUPDATEをしたいのです...
-
SQL*LoaderでCSVから指定した列...
-
SQLでSUMなどの関数でデータが...
-
sqlplusで表示が変なので、出力...
-
カラム位置変更
-
件数とデータを同時に取得する...
-
SQL 複数テーブルのupdate
-
特定のカラムが更新されたとき...
-
OracleのSQLで同テーブルのカラ...
-
数値をNUMBER型にするかCHAR型...
-
UPDATE文
-
LONG型の先頭250バイトを Varch...
-
SQLで違うテーブルの値を比較し...
-
DELETE文とロックについて
-
PLSQLのNumber型の初期化
-
SQL(oracle)でご助言いただきた...
-
半角英数文字の抽出がしたい。
おすすめ情報
回答誠にありがとうございます。
Noはただの項番であり、キーはIDになるのです。
ご提示頂いたSQL文だと、キーがNoになっており、おかしい抽出になってしまいます。
NoをIDに変えれば宜しいのですかね。。。
existsを使用し、ちょっと試してみます。
ありがとうございます。