下記のようなテーブルがあった場合に、
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で質問しましょう!
似たような質問が見つかりました
- Oracle sqlで質問です。 aテーブルとbテーブルがあり、下記のsqlで取得したidとnameに一致しないレ 1 2022/04/20 20:34
- Access(アクセス) アクセス IDが空白の時、メッセージボックスがでるようにするには 1 2022/08/04 11:06
- SQL Server ACCESSで表が作りたく、そのためのSQL文や設定方法を教えてください。 1 2022/08/15 12:28
- Oracle sqlで質問です。 idを元にidに紐付くデータで住所コードがjpのみのデータ以外のidを取得したい 4 2023/03/20 17:41
- C言語・C++・C# C言語初心者です、、、お助けください 2 2023/03/14 20:08
- Access(アクセス) アクセス 削除するレコードを含んだテーブルを指定してくださいのエラー対処方法 1 2022/11/24 15:01
- 経営情報システム accessでの請求管理について 12 2022/06/11 16:20
- Access(アクセス) DoCmd.SearchForRecord が動かない時の解決方法 3 2022/07/22 15:31
- JavaScript Javascript初心者|jQueryの.val()で値を取得し複数の要素を連結させる方法知りたい 2 2022/06/02 12:06
- Visual Basic(VBA) ExcelからAccessのテーブルに書き込む時に時間がかかる 1 2022/10/14 20:38
このQ&Aを見た人はこんなQ&Aも見ています
-
新NISA制度は今までと何が変わる?非課税枠の拡大や投資対象の変更などを解説!
少額から投資を行う人のための非課税制度であるNISAが、2024年に改正される。おすすめの銘柄や投資額の目安について教えてもらった。
-
MAX関数を使ってからLEFT JOINしたいのですが・・
PHP
-
group byで指定したカラム以外のカラムの値を取得したい
PostgreSQL
-
SQLで特定の項目の重複のみを排除した全項目を取得する方法
その他(プログラミング・Web制作)
-
-
4
SQLで部分的にGROUP BYしたいとき
Oracle
-
5
バッチファイル 二つ上のディレクトリのパス取得
その他(プログラミング・Web制作)
-
6
GROUP BYを行った後に結合したい。
Oracle
-
7
2つの項目が重複するレコードを抽出する方法はありますか?
MySQL
-
8
SELECT 文 GROUP での1件目を取得
SQL Server
-
9
SELECT INTOで一度に複数の変数へ代入をするにはどのようにすれがよいでしょうか?
PostgreSQL
-
10
複数テーブルのMAX値の行データを取得したい
Oracle
-
11
SELECTで1件のみ取得するには?
Oracle
-
12
SQLServer2005のSQL文での別名の取り扱い
SQL Server
-
13
エクセル:マクロ「Application.CutCopyMode = False」って?
Excel(エクセル)
-
14
コマンドプロンプトの「%1」と「%~1」の違いがわからない
その他(プログラミング・Web制作)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
VIEWの元のテーブルのindexって...
-
insertを高速化させたい
-
副問合せの書き方について
-
SQL Left Join で重複を排除す...
-
ある条件の最大値+1を初番する...
-
selectした大量データをinsert...
-
マイクラPC版のコマンドで効率...
-
select文のwhere句に配列を入れ...
-
一つ前のレコードの値と減算し...
-
my_itemsテーブルのIDにAUTO_IN...
-
期間の重複を調べるSQL文につい...
-
1対多結合で多を絞り込み条件と...
-
SELECT~LIKE~の結果が変
-
1テーブル&複数レコードの更新...
-
MySQLにてCOUNTした値を更にCOUNT
-
エクセルの関数について教えて...
-
Unionした最後にGROUP BYを追加...
-
SQLサーバから、項目の属性(型...
-
バインド変数について
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
SQL Left Join で重複を排除す...
-
VIEWの元のテーブルのindexって...
-
SQLサーバから、項目の属性(型...
-
select文のwhere句に配列を入れ...
-
副問合せの書き方について
-
マイクラPC版のコマンドで効率...
-
Unionした最後にGROUP BYを追加...
-
selectした大量データをinsert...
-
SQLにて特定の文字を除いた検索...
-
[SQLServer] テーブル名からカ...
-
1テーブル&複数レコードの更新...
-
inner joinをすると数がおかし...
-
クエリ表示と、ADOで抽出したレ...
-
ある条件の最大値+1を初番する...
-
sqlで、600行あるテーブルを100...
-
複数テーブルのGROUP BY の使い...
-
insertを高速化させたい
-
PL/SQLの変数について
-
キー毎の、ある列のmaxのレコー...
おすすめ情報