
下記のようなテーブルがあった場合に、
ID1|ID2|価格
-----------------------
1 | 1 | 100
1 | 2 | 200
1 | 3 | 150
2 | 1 | 1000
2 | 2 | 500
3 | 1 | 50
3 | 2 | 100
下記のようなレコードを返してくるSQLを教えて下さい。
ID1 | ID2 | 価格
-----------------------
1 | 3 | 150
2 | 2 | 500
3 | 2 | 100
要するに、ID1毎に、ID2が最大のレコードを取得し、価格列の数値を使いたいのです。
基本的なSQLは理解しているつもりなのですが・・・。
ご回答よろしくお願いします。
No.2ベストアンサー
- 回答日時:
SQL> select * from test;
ID1 ID2 XXX
---------- ---------- ----------
1 1 100
1 2 200
1 3 150
2 1 1000
2 2 500
3 1 50
3 2 100
7行が選択されました。
SQL> select ID1
2 ,max(ID2) as ID2
3 ,max(XXX)keep(dense_rank Last order by ID2) as XXX
4 from test
5 group by ID1;
ID1 ID2 XXX
---------- ---------- ----------
1 3 150
2 2 500
3 2 100
SQL>
No.1
- 回答日時:
select * from tbl t1
where not exists
( select 1 from tbl t2
where t1.id1=t2.id1
and t1.id2<t2.id2)
とか
select * from tbl t1
where id2 >= all(select id2 from tbl t2 where t1.id1=t2.id1)
とか
やっぱりexists使わないとだめっすかねー
パフォーマンス的にだいぶ劣るような気がした&慣れてない ので、できれば回避したかったんですが。
諦めて、ご提案のSQLを使う方向でじっくりとやってみます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
エクセルの関数について教えて...
-
sqlで、600行あるテーブルを100...
-
SQLサーバから、項目の属性(型...
-
VIEWの元のテーブルのindexって...
-
クエリ表示と、ADOで抽出したレ...
-
LAST_INSERT_IDで同時にアクセ...
-
Updateの複数テーブル条件時のL...
-
SQL Left Join で重複を排除す...
-
グラビアアイドルからAV女優に...
-
【Transact-sql】 execの結果を...
-
証明写真機の設置場所が知りたい
-
PL/SQLの変数について
-
期間の重複を調べるSQL文につい...
-
load dataするときに、最後の列...
-
入力値と外部キーをINSERTするには
-
1テーブル&複数レコードの更新...
-
VMware Playerで拡張子「vmx」...
-
全角文字を含む行を検索
-
MySQL5でキーがないテーブルの...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
エクセルの関数について教えて...
-
VIEWの元のテーブルのindexって...
-
エラー 1068 (42000): 複数の主...
-
SQLサーバから、項目の属性(型...
-
select文のwhere句に配列を入れ...
-
SQL Left Join で重複を排除す...
-
Access パラメータクエリをcsv...
-
マイクラPC版のコマンドで効率...
-
【Transact-sql】 execの結果を...
-
sqlで、600行あるテーブルを100...
-
SQLにて特定の文字を除いた検索...
-
1テーブル&複数レコードの更新...
-
PL/SQLの変数について
-
WordpressのContact form 7でzi...
-
複数テーブルのGROUP BY の使い...
-
バインド変数について
-
inner joinをすると数がおかし...
-
MySQLのint型で001と表示する方...
-
updateを1行ずつ実行したい。
おすすめ情報