お世話になります。
ORACLEのMAX()関数を使用して、
下記内容を取得するSQLを作成しています。
・商品テーブルから商品コードを取得したい
・上記の取得条件として、商品テーブルの日付項目が最新日付のレコードのみを
取得したい
・上記の取得条件に加えて、指定したいくつかの商品に該当するもののみを
検索対象としたい
【SQLサンプル】
SELECT
商品コード
FROM
商品テーブル
WHERE
商品コード IN (101, 102, 103)
AND 在庫区分 = '0'
AND 日付 = (SELECT MAX(日付) FROM 商品テーブル
WHERE 商品コード IN (101, 102, 103)
AND 在庫区分 = '0'
)
AND ランク = (SELECT MAX(ランク) FROM 商品テーブル
WHERE 商品コード IN (101, 102, 103)
AND 在庫区分 = '0'
)
上記以外の書き方で何か良い書き方があれば、
ご教授願えますか? よろしくお願いいたします。
No.2ベストアンサー
- 回答日時:
データの内容がわからないのではっきりとはいえませんが、
データの内容によっては、質問のSQLはまずいです。
商品コード,日付
101,5/5
102,5/6
103,5/4
とあると、102しかとってこないのでは?
普通は、
SELECT
商品コード
FROM
商品テーブル X
WHERE
商品コード IN (101, 102, 103)
AND 在庫区分 = '0'
AND 日付 = (SELECT MAX(日付) FROM 商品テーブル Y
WHERE X.商品コード = Y.商品コード
AND Y.在庫区分 = '0'
)
とします。
で、もう1点問題があって
ランク
の部分です。
商品コード,日付,ランク
101,5/5,3
101,5/6,2
とあるとどちらを優先ですか?
このパターンがないとして、
商品コード,日付,ランク
101,5/5,3
101,5/5,2
101,5/5,1
のようなデータが入っているので、
最大の日付を優先とすると、
AND X.ランク = (SELECT MAX(ランク) FROM 商品テーブル Z
WHERE X.商品コード = Z.商品コード
AND Z.在庫区分 = '0'
AND Z.日付 = (SELECT MAX(日付) FROM 商品テーブル Q
WHERE Q.商品コード = Z.商品コード
AND Q.在庫区分 = '0'
)
)
とでもしますか。
別の方法
SELECT
X.商品コード
FROM
商品テーブル X,
(
SELECT
商品コード,MAX(日付) as 日付
FROM
商品テーブル
WHERE
商品コード IN (101, 102, 103)
AND 在庫区分 = '0'
group by 商品コード) Y,
(
SELECT
商品コード,日付,MAX(ランク) as ランク
FROM
商品テーブル
WHERE
商品コード IN (101, 102, 103)
AND 在庫区分 = '0'
group by 商品コード,日付) Z
WHERE x.商品コード IN (101, 102, 103)
AND x.在庫区分 = '0'
AND x.商品コード = Y.商品コード
AND x.日付 = Y.日付
AND x.商品コード = Z.商品コード
AND Y.日付 = Z.日付
AMD x.ランク = Z.ランク
という方法もあります。
(副問い合わせで抽出された結果のデータ量が多いとリソースを食うし、レスポンスは悪いですが。)
No.1
- 回答日時:
>・上記の取得条件として、商品テーブルの日付項目が最新日付のレコードのみを取得したい
とありますが、記載のSQLは「日付が最新」かつ「ランクが最大」となっていますよね。
とりあえず、記載のSQLをベースにしました。
ORACLEのバージョンが書いていないのですが、分析関数が使える(9i?)なら。
SELECT
商品コード
FROM (
SELECT
商品コード,日付,ランク
,MAX(日付) OVER() MAX日付
,MAX(ランク) OVER() MAXランク
FROM
商品テーブル
WHERE
商品コード IN (101, 102, 103)
AND 在庫区分 = '0')
WHERE
日付 = MAX日付 AND ランク = MAXランク;
とか。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
「マスタ」と「テーブル」の違...
-
重複するキーから一番古い年月...
-
Accessでフィールドを比較した...
-
2つのテーブルから条件に一致...
-
テーブルとテーブルを繋ぐユニ...
-
Access2010 「型が一致しません...
-
アクセスのクエリの作り方
-
OracleのUnion内でそれぞれのOr...
-
自分自身への矢印
-
ACCESS 一つのフィールドに複...
-
請求と入金のテーブルの作成の...
-
SQL 2つのテーブルとSUBSTRING...
-
PLSQLの識別子エラー
-
3つ以上のテーブルをUNIONする...
-
Accessにインポートしたら並び...
-
データの二重表示の原因
-
エクスポート時の改行コードに...
-
mysql IN句に1データだけ指定...
-
SELECT時の行ロックの必要性に...
-
ACCESS2007 フォーム 「バリア...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
「マスタ」と「テーブル」の違...
-
重複するキーから一番古い年月...
-
2つのテーブルから条件に一致...
-
ACCESS 一つのフィールドに複...
-
行方向のデータを横に並べる
-
主キーの変更
-
PLSQLの識別子エラー
-
ACCESSのコンパイルエラーについて
-
Accessでフィールドを比較した...
-
Inner join と Left joinの明...
-
続.ORACLEのSELECTのソートに...
-
片方だけ抽出する方法(SQL)
-
accessで移動平均する方法
-
SQL 2つのテーブルとSUBSTRING...
-
商品コード番号を入力すると商...
-
Accessユニオンクエリーで2つ...
-
発注テーブルの発注残数を納品...
-
請求と入金のテーブルの作成の...
-
下記のsqlで取得されるレコード...
-
日報計算
おすすめ情報