ORACLE環境下、SQLにて以下のような条件でデータを取得したいです。
AテーブルとBテーブルを結合して、Bテーブルから名称を取得する。
<Aテーブル>
id (key) 番号1 番号2
A01 001 n0001
A02 null n0002
<Bテーブル>
code(key) 名前 番号1 番号2
c0001 太郎 001 n0001
c0002 次郎 002 n0002
(1)A.番号が入力されていれば
A.番号1=B.番号1 AND A.番号2=B.番号2を条件にする
(2)A.番号が入力されていなければ
A.番号=B.番号を条件からはずす。
A.番号2=B.番号2 のみで検索する。
<欲しい結果>
A01→太郎を取得
A02→次郎を取得
入力されていたら条件に加え、入力されていなかったら
条件から外す、というSQLを教えていただけないでしょうか。
よろしくお願いいたします。
A 回答 (6件)
- 最新から表示
- 回答順に表示
No.6
- 回答日時:
#5です。
Bテーブルとエイリアスが不足してました。(1)と(2)をunionしてはどうでしょう?
select a.id, b.名前 from Aテーブル a, Bテーブル b where a.番号1 is not null and a.番号1 = b.番号1
union
select a.id, b.名前 from Aテーブル a, Bテーブル b where a.番号1 is null and a.番号2 = b.番号2
;
No.5
- 回答日時:
(1)と(2)をunionしてはどうでしょう?
select a.id, b.名前 from Aテーブル where a.番号1 is not null and a.番号1 = b.番号1
union
select a.id, b.名前 from Aテーブル where a.番号1 is null and a.番号2 = b.番号2
;
No.4
- 回答日時:
>nullの場合は条件から完全に外したいのです。
の意図がよく分かりません・・・
さきほどのSQLで希望の結果になると思うのですが。
SQLから消したいのであれば、プログラムで動的にSQLを組み立てればいいのではないでしょうか。
No.2
- 回答日時:
orで二つの条件を書く。
select a.id, b.名前
from Aテーブル a
inner join Bテーブル b on (
(b.番号1 = a.番号1 and b.番号2 = a.番号2)
or
(a.番号1 is null and b.番号2 = a.番号2)
);
もしくは、Aテーブルの番号1がnullのときはBテーブルの番号1で結合する。
ただし、こちらの方法ではBテーブルの番号1にnullが入る場合はうまくいきません。
select a.id, b.名前
from Aテーブル a
inner join Bテーブル b
on (
b.番号1 = nvl(a.番号1,b.番号1) and b.番号2 = b.番号2
);
でどうでしょうか。
この回答への補足
回答いただきありがとうございます。
nullの場合は条件から完全に外したいのです。
※番号1 is null の場合、nullで検索しない。
もし代案ありましたらよろしくお願いします。
No.1
- 回答日時:
orで2つの条件を書く。
select a.id, b.名前
from Aテーブル a
inner join Bテーブル b on (
(b.番号1 = a.番号1 and b.番号2 = a.番号2)
or
(a.番号1 is null and b.番号2 = a.番号2)
);
もしくは、Aテーブルの番号1がnullのときはBテーブルの番号1で結合する(=全件ヒット)。
select a.id, b.名前
from Aテーブル a
inner join Bテーブル b on (
b.番号1 = nvl(a.番号1,b.番号1) and b.番号2 = a.番号2
);
でどうでしょうか。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Oracle 質問です。 下記のテーブルとデータがあり、 取得想定結果のように出力したいです。 下記のsqlだと0 2 2023/05/23 19:10
- Oracle sqlのupdate文で質問です。 テーブルBの番号をキーにテーブルAの身長をテーブルBの身長に更新 2 2022/11/02 15:15
- Oracle sqlで質問です。 Aテーブルの登録番号をキーにBテーブルから確認番号を取得したいのですが、Bテーブ 4 2023/05/18 13:08
- Oracle sqlで質問です。 Aテーブルの情報をBテーブルに更新かけたいです。 やりたいことは、Bテーブルの受 1 2023/05/17 11:17
- Oracle 下記のsqlで取得されるレコード以外を取得する方法ありますでしょうか。 SELECT B.番号, B 2 2022/04/20 23:21
- Oracle update文で質問です。 下記の条件でupdateをしたいですが、どのようにしたら良いでしょうか。 2 2022/06/23 10:51
- Access(アクセス) Accessでセレクタをダブルクリックで別フォームで詳細表示 3 2022/12/20 10:36
- Excel(エクセル) 条件付き書式 別のシートで色付けされたセルデータの転記漏れを防ぐ書式を入れたい 4 2022/04/22 06:36
- Access(アクセス) Access DLookup vbaで条件を2件設定したい場合どうすればよいでですか? 現在 If( 1 2023/06/28 14:28
- その他(Microsoft Office) EXCELの1行を1枚の用紙にそれぞれ印刷したい。 3 2022/10/10 11:35
このQ&Aを見た人はこんなQ&Aも見ています
-
10代と話して驚いたこと
先日10代の知り合いと話した際、フロッピーディスクの実物を見たことがない、と言われて驚きました。今後もこういうことが増えてくるのかと思うと不思議な気持ちです。
-
大人になっても苦手な食べ物、ありますか?
大人になっても、我慢してもどうしても食べれないほど苦手なものってありますよね。 あなたにとっての今でもどうしても苦手なものはなんですか?
-
初めて自分の家と他人の家が違う、と意識した時
子供の頃、友達の家に行くと「なんか自分の家と匂いが違うな?」って思いませんでしたか?
-
自分のセンスや笑いの好みに影響を受けた作品を教えて
子どもの頃に読んだ漫画などが その後の笑いの好みや自分自身のユーモアのセンスに影響することがあると思いますが、 「この作品に影響受けてるな~!」というものがあれば教えてください。
-
14歳の自分に衝撃の事実を告げてください
タイムマシンで14歳の自分のところに現れた未来のあなた。 衝撃的な事実を告げて自分に驚かせるとしたら何を告げますか?
-
引数によってwhere句を切り替える方法
Oracle
-
特定条件でWHERE句の条件を変更したい
SQL Server
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・【大喜利】【投稿~11/12】 急に朝起こしてきた母親に言われた一言とは?
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・好きな「お肉」は?
- ・あなたは何にトキメキますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・ハマっている「お菓子」を教えて!
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
「マスタ」と「テーブル」の違...
-
重複するキーから一番古い年月...
-
続.ORACLEのSELECTのソートに...
-
2つのテーブルから条件に一致...
-
Accessでフィールドを比較した...
-
主キーの変更
-
ACCESSのSQLで、NULLかNULLでな...
-
DB2でSelectした時(rollback,c...
-
3つ以上のテーブルをUNIONする...
-
データの二重表示の原因
-
ACCESS2007 フォーム 「バリア...
-
オラクルではできるのにSQLSERV...
-
SI Object Browserのテーブルス...
-
SELECT文でのデッドロックに対...
-
sqlserverで集計結果をUPDATEし...
-
Access のリレーションシップで...
-
Accessにインポートしたら並び...
-
インデックスの再構築の意味っ...
-
Access VBA Me.Requery レコー...
-
ADOでSeekメッソッドが使えませ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
「マスタ」と「テーブル」の違...
-
2つのテーブルから条件に一致...
-
重複するキーから一番古い年月...
-
ACCESS 一つのフィールドに複...
-
行方向のデータを横に並べる
-
PLSQLの識別子エラー
-
Accessでフィールドを比較した...
-
主キーの変更
-
続.ORACLEのSELECTのソートに...
-
Inner join と Left joinの明...
-
商品コード番号を入力すると商...
-
SQL 2つのテーブルとSUBSTRING...
-
ACCESSのコンパイルエラーについて
-
ACCESS2000でDCount関数の使い方
-
自分自身への矢印
-
請求と入金のテーブルの作成の...
-
Accessユニオンクエリーで2つ...
-
VIEWでテーブルの集計結果...
-
OracleのUnion内でそれぞれのOr...
-
【Access初心者】最大値と次に...
おすすめ情報