
SQL文で質問です。
テーブルA
X NUMBER型
Y DATE型(年月日と時間)
テーブルB
Z NUMBER型
W DATE型(年月日)
A,BをAを主テーブルとして外部結合し、同じ年月日でBには無いデータ
を取得したいのですが、
SELECT A.X FROM A,B
WHERE A.X = B.Z(+) AND
A.Y = B.W(+) AND
B.Z IS NULL;
というSQL文を実行すると、テーブルAには時間まで登録されているので
実際には取得したいデータが存在しても
「レコードが選択されませんでした」
になってしまいます。このため、
SELECT A.X FROM A,B
WHERE A.X = B.Z(+) AND
TO_DATE(A.Y,'YYYY/MM/DD') = TO_DATE(B.W,'YYYY/MM/DD')(+) AND
B.Z IS NULL;
としてみたところ、今度は3行目で
「ORA-00936: 式がありません」
というエラーになってしまいます。
外部結合にしたことがエラーの原因のようなのですが、DATE型の項目を
キーにして外部結合にするにはどうすれば良いのでしょうか?
No.3
- 回答日時:
既にn_breakdownさんに書かれてしまいましたが
SQLリファレンスの「SQL問い合わせ及び副問い合わせ」の「結合」に
「結合演算子(+)は任意の式ではなく、列にのみ適用することができます。」
とありますので、TO_DATEやTO_CHAR、truncではエラーになります。
9i以降であればleft joinを使って
select a.x from a
left join b on a.x=b.z
and trunc(b.w) =trunc(a.y)
where b.z is null
ではどうでしょうか?
#8iだとちょっと副問い合わせ(もしくはview)を使うしかなさそうです。
Oracleのバージョンは10gです。
試してみたところ、TRUNCを使用した行で
「ORA-00904:"A"."Y":無効な識別子です」
のエラーになってしまいました。
取り急ぎn_breakdownさんに教えて頂いた方法をとり、
上記エラーについては後日調べてみることにします。
どうもありがとうございました。
No.1
- 回答日時:
SELECT A.X
FROM A,B
WHERE A.X = B.Z (+)
AND TRUNC(A.Y) = TRUNC(B.W) (+)
AND B.Z IS NULL;
でうまくいきませんか?
この回答への補足
ご回答ありがとうございます。
教えて頂いた通りにやってみましたが、やはり同じ
「ORA-00936: 式がありません」
のエラーが出てしまいます…
それからすみません、質問文を間違えてしまいました。
最初のSQLの実行結果は「レコードが選択されませんでした」ではなく、
全てのレコードが選択されてしまいます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Oracle 下記のsqlで取得されるレコード以外を取得する方法ありますでしょうか。 SELECT B.番号, B 2 2022/04/20 23:21
- Oracle 質問です。 下記のテーブルとデータがあり、 取得想定結果のように出力したいです。 下記のsqlだと0 2 2023/05/23 19:10
- MySQL PhpMyAdminで作成して実行せよ。 東京23区を、皇居を中心とした4つのエリア(南東, 南西, 1 2023/06/11 11:58
- Oracle sqlで質問です。 aテーブルとbテーブルがあり、下記のsqlで取得したidとnameに一致しないレ 1 2022/04/20 20:34
- MySQL SQLです。下記の問合せを行うクエリを、PhpMyAdminで作成して実行せよ。 「昨年の各月の総降 1 2023/07/01 00:32
- Visual Basic(VBA) データベースから絞り込んでデータを読み込み 1 2023/02/21 19:51
- PostgreSQL DBFluteについて質問です。 環境:PostgreSQL java8 前提:webアプリケーショ 1 2022/07/07 00:49
- SQL Server [SQLServer] テーブル名からカラム名を取得する 1 2022/08/23 21:20
- JavaScript gasについて 1 2022/05/31 21:51
- Oracle sqlで質問です。 Aテーブルの登録番号をキーにBテーブルから確認番号を取得したいのですが、Bテーブ 4 2023/05/18 13:08
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・一番好きなみそ汁の具材は?
- ・泣きながら食べたご飯の思い出
- ・「これはヤバかったな」という遅刻エピソード
- ・初めて自分の家と他人の家が違う、と意識した時
- ・いちばん失敗した人決定戦
- ・思い出すきっかけは 音楽?におい?景色?
- ・あなたなりのストレス発散方法を教えてください!
- ・もし10億円当たったら何に使いますか?
- ・何回やってもうまくいかないことは?
- ・今年はじめたいことは?
- ・あなたの人生で一番ピンチに陥った瞬間は?
- ・初めて見た映画を教えてください!
- ・今の日本に期待することはなんですか?
- ・集中するためにやっていること
- ・テレビやラジオに出たことがある人、いますか?
- ・【お題】斜め上を行くスキー場にありがちなこと
- ・人生でいちばんスベッた瞬間
- ・コーピングについて教えてください
- ・あなたの「プチ贅沢」はなんですか?
- ・コンビニでおにぎりを買うときのスタメンはどの具?
- ・おすすめの美術館・博物館、教えてください!
- ・【お題】大変な警告
- ・洋服何着持ってますか?
- ・みんなの【マイ・ベスト積読2024】を教えてください。
- ・「これいらなくない?」という慣習、教えてください
- ・今から楽しみな予定はありますか?
- ・AIツールの活用方法を教えて
- ・最強の防寒、あったか術を教えてください!
- ・歳とったな〜〜と思ったことは?
- ・モテ期を経験した方いらっしゃいますか?
- ・好きな人を振り向かせるためにしたこと
- ・スマホに会話を聞かれているな!?と思ったことありますか?
- ・それもChatGPT!?と驚いた使用方法を教えてください
- ・見学に行くとしたら【天国】と【地獄】どっち?
- ・これまでで一番「情けなかったとき」はいつですか?
- ・この人頭いいなと思ったエピソード
- ・あなたの「必」の書き順を教えてください
- ・14歳の自分に衝撃の事実を告げてください
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
select句副問い合わせ 値の個...
-
GROUP BYを行った後に結合した...
-
SELECTの結果で同一行を複数回...
-
select insertで複数テーブルか...
-
oracleの分割delete
-
外部結合とor条件混在の記述方法
-
MERGE文を単体テーブルに対して...
-
SQL GROUPで件数の一番多いレコ...
-
半角英数字混在データから数字...
-
unionでマージした副問合せを結合
-
集計後の数値が倍になる
-
他のテーブルを参照した値はupd...
-
DELETE 文とEXISTSの使い方につ...
-
select文でフリーズします。
-
SQLの書き方(チェックボックス)
-
SET句内で複数の条件を指定して...
-
固定値を含む結合と複数テーブ...
-
異なるテーブルのレコード削除
-
Oracleでの文字列連結サイズの上限
-
OracleのSQL*PLUSで、デー...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
GROUP BYを行った後に結合した...
-
select句副問い合わせ 値の個...
-
select insertで複数テーブルか...
-
SELECTの結果で同一行を複数回...
-
固定値を含む結合と複数テーブ...
-
外部結合とor条件混在の記述方法
-
oracleの分割delete
-
MERGE文を単体テーブルに対して...
-
SQL GROUPで件数の一番多いレコ...
-
複数テーブルのMAX値の行データ...
-
他のテーブルを参照した値はupd...
-
unionでマージした副問合せを結合
-
SET句内で複数の条件を指定して...
-
unionの結果は集計はできないで...
-
SQLの書き方(チェックボックス)
-
DELETE 文とEXISTSの使い方につ...
-
updateの一括実行
-
select文でフリーズします。
-
集計後の数値が倍になる
-
テーブルの列名をデータとして...
おすすめ情報