一つのテーブル(TABLE_A)に次のフィールドがあります。
SEQ_RID, TARGET_REGION, YEAR, SELL_PRICE
1 , 1 , 1997, 1100
2 , 1 , 1997, 1700
3 , 1 , 1997, 1300
4 , 2 , 1997, 1400
5 , 2 , 1997, 1500
6 , 2 , 1998, 1700
7 , 2 , 1998, 1800
8 , 2 , 1998, 1200
....
各TRAGET_REGION別の最新年(YEAR)の最大売上(SELL_PRICE)を
求めたいと思います。
MAX関数を二つ使うのはだめみたいです。
宜しくお願いします。
No.2ベストアンサー
- 回答日時:
postgreSQLなんかだと
select * from t1 x
where not exists
( select 1 from t1 y
where x.TARGET_REGION=y.TARGET_REGION
and ( x.YEAR, x.SELL_PRICE ) < ( y.YEAR ,y.SELL_PRICE ) );
でいけると思うけど。SQLServerとかORACLEでは行構築子の大小比較が
できないから。
select * from t1 x
where not exists
( select 1 from t1 y
where x.TARGET_REGION=y.TARGET_REGION
and ( x.YEAR<y.YEAR or ( x.YEAR=y.YEAR and x.SELL_PRICE<y.SELL_PRICE ) ) );
でどうでしょう。
No.3
- 回答日時:
ANo.2です。
後段のSQL試してみました?
これならSQLServer2000でもいけると思ったんですが。
後段のSQLを試してみました。
最初はPostgreのみだと思い込みまして、SQL2000では実行できないと
おもいましたが、改めてテストしてみた結果うまくいきました。
本当にありがとうございます。
ちなみに、同じ年度の最高の売上が複数存在する場合を想定してdistinctをつけました。
select distinct TARGET_REGION, YEAR, SELL_PRICE from test1 x
where not exists
( select 1 from test1 y
where x.TARGET_REGION=y.TARGET_REGION
and ( x.YEAR<y.YEAR or ( x.YEAR=y.YEAR and x.SELL_PRICE<y.SELL_PRICE ) ) );
もう一度お礼を申し上げます、ありがとうございます。
No.1
- 回答日時:
SQL SERVERのバージョンは?
>MAX関数を二つ使うのはだめみたいです。
何がどうだめなのですか?
丸投げにせず、自分なりに考えたSQLを提示してくれれば、どこに問題があるか具体的に示せるのですけどね。また、丸投げは、ここの規約違反ですし。
単純にMAX値を得るのでなく、TARGET_REGION毎に最大のYEARを求め、その同じ行の中でMAXのSELL_PRICEを求める必要があるので、その辺の条件が足らないのでは?
SQL SERVER 2005以降なら、分析関数を使用できます。
SELECT *
FROM
(SELECT
RANK() OVER(PARTITION BY TARGET_REGION ORDER BY "YEAR" DESC,SELL_PRICE DESC) AS RK,
*
FROM TABLE_A) AS X
WHERE X.RK=1
ORDER BY TARGET_REGION
ご回答及びご指導、ありがとうございます。
自分なりに考えたのは、以下のものです。
select t1.TARGET_REGION, t1.MAX_YEAR, t2.MAX_SELL_PRICE
--地域ごとの最新年度を求める
(select TARGET_REGION, MAX(YEAR) MAX_YEAR
from TABLE_A
group by TARGET_REGION) as t1,
--地域毎年度毎の最高の売上を求める
(select TARGET_REGION, YEAR, MAX(SELL_PRICE) MAX_SELL_PRICE
from TABLE_A
group by TARGET_RGION, YEAR) as t2
where t1.TARGET_REGION = t2.TARGET_REGION
and t1.MAX_YEAR = t2.YEAR
お時間が許される限り、ご検討いただければと思います。
ありがとうございます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- 数学 数学 3次関数の最小値・最大値を求める際 その関数を微分した二次関数を平方完成し最小値を求めるやり方 3 2023/05/02 01:13
- 数学 数1 二次関数 関数 y=x^2-2x-1について、定義域が-1<x<2のとき、最大値最小値を求めよ 5 2023/06/06 12:00
- Access(アクセス) Accessテーブルの結合で別々のテーブルのフィールドを組み合わせて値を出す方法について 2 2022/07/20 19:43
- 英語 関係代名詞についてちょっとマニアックな文法的な質問です。 There are various con 3 2022/05/05 12:45
- 数学 数学 2時間数に関わる問題について教えてください。 x≧1 y≧-1 2x+y=5 であるとき、xy 7 2022/10/29 10:57
- 数学 【高1 数学Ⅰ 二次関数】 二次関数 f(x)=x^2-4ax+8a がある。ただし、aは正の定数と 3 2022/07/23 15:46
- 数学 条件付き極値問題といわれる問題です。ラグランジュの乗数法 について、質問したいことがあります。 条件 3 2023/05/15 21:38
- その他(データベース) 更新クエリをリンクデータベーステーブルに実行し実行時エラー3362固有インデックスに重複する値が含ま 1 2022/09/21 11:44
- 数学 正数a、bに対し次の関数の最大値、最小値(もしあれば)を求めよ (1)x ^a(1-x)^b (0≦ 2 2023/07/19 17:29
- 数学 至急!!二次関数について aは定数とする。関数y=-x²+2ax-4a+1(-1≦x≦2)の最小値を 5 2023/06/27 23:28
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Oracleで「文字が無効です」の...
-
2つの列が同じ値の行を取得するSQL
-
枝番の最大値とその前のデータ...
-
SQLローダーCSV取込で、囲み文...
-
単一グループのグループ関数で...
-
<SQL>重複しているデータの場合...
-
select文の実行結果に空白行を...
-
並べ替えについて
-
【PL/SQL】FROM区に変数を使う方法
-
2回実行のSQL文を1回にしたい
-
Selectした時のレコードの取得順
-
トランザクションログを出力せ...
-
テーブルの最後(最新)のレコー...
-
レコードの登録順がおかしい
-
複数のテーブルから値を合計出...
-
count関数の値をwhere句で使用...
-
1の行を固定した上でVBAを用い...
-
SELECT FOR UPDATE で該当レコ...
-
SQLで条件にヒットしたレコード...
-
SQL*Loader Append
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
2つの列が同じ値の行を取得するSQL
-
Oracleで「文字が無効です」の...
-
PL/SQLで…SQLの実行結果を変数...
-
枝番の最大値とその前のデータ...
-
並び替えた後の表の結合
-
同じテーブルからviewを作成し...
-
UPDATE文のWHERE句にファンクシ...
-
最新かつ最大の値を求める
-
Accessオプションボタン vba case
-
Oracleでビット演算はできますか?
-
SQLローダーCSV取込で、囲み文...
-
単一グループのグループ関数で...
-
select文の実行結果に空白行を...
-
テーブルの最後(最新)のレコー...
-
count関数の値をwhere句で使用...
-
【PL/SQL】FROM区に変数を使う方法
-
SELECT FOR UPDATE で該当レコ...
-
レコードの登録順がおかしい
-
<SQL>重複しているデータの場合...
-
AccessのSQL文で1件のみヒット...
おすすめ情報