![](http://oshiete.xgoo.jp/images/v2/pc/qa/question_title.png?8acaa2e)
![](http://oshiete.xgoo.jp/images/v2/common/profile/M/noimageicon_setting_12.png?8acaa2e)
テーブルAを複数のキー項目で集約した結果と、テーブルBを結合しようとしています。
インラインビュー(もしくはビュー)で予め集約を行う、以下のようなSQLを考えました。
候補<1> MAX関数でTableA.列1を絞る
select ...
from (select max(列1),列2,列3,列4 from TableA group by 列2,列3,列4) TableA2,Table_B
where TableA.列2=TableB.列2
and ...;
候補<2> ROW_NUMBER関数で列1の順位を取得し、Where句で順位=1とすることでTableA.列1を絞る
select ...
from (select 列2,列3,列4 from TableA group by 列2,列3,列4
row_number() over (partition by 列2,列3,列4 order by 列1) RN) TableA2,Table_B
where TableA.列2=TableB.列2
and ...
and RN=1;
※候補<1><2>で結果が異なることがありますが、ともかく
「インラインビュー(もしくはビュー)で予め集約を行う」がやりたいことです。
しかしこのようなクエリだと、インラインビューでもビューでも、
性能がでません。実行計画を確認したところ、TableA,TableBの結合で生成される
レコードごとに毎回集約を行っているようで、膨大なクエリ数が発生していました。
ビューやインラインビューで上記のように集約を行うと危険、とはよく聞きますが...
ビューやインラインビューで集約した結果をひとつのテーブルとみなして結合するなど、
レコードごとに集約を行わないようなノウハウがありましたら、お教え願います。
No.1ベストアンサー
- 回答日時:
select /*+ ORDERED */ *
FROM
(select * from (select X.*,row_number() ~ from TableA x) where R=1) A,
Table B
where A.列2=B.列2
;
結合順を明確化し、レコードの選択を分離すれば、ねらい通りの順番で
動くのじゃないとか思いますが..
使っているオプティマイザ次第なので..
ご回答ありがとうございます。そんな方法があるのですね。参考になります。
ただ、使用している製品(SQLを生成して発行するツール)の仕様や環境等の都合上、HINTを使用できないので、「/*+ ORDERED */」は使用できません...。
いっそのこと、集約テーブル(上記例ではTableA)をあらかじめデータマートとして作成しておこうかと考えています。
最初の説明が不足しておりまして、申し訳ありません。
ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- MySQL SQLです。こんな感じですか?あってますか? うまくいきません教えてくださいお願いします 1 2023/07/08 15:27
- MySQL うまくいきません教えてくださいお願いしますSQLです。クエリ構文です。 1 2023/07/07 12:39
- SQL Server [SQLServer] テーブル名からカラム名を取得する 1 2022/08/23 21:20
- Oracle SQLについて教えて下さい。 主キーを持ったカラムを主キーの機能を持たせたまま カンマ区切りで文字列 1 2023/03/27 22:47
- Access(アクセス) アクセス where句を使用して複数条件抽出をするには 2 2022/08/29 13:24
- MySQL PhpMyAdminで作成して実行せよ。 東京23区を、皇居を中心とした4つのエリア(南東, 南西, 1 2023/06/11 11:58
- MySQL 下記の問合せを行うクエリを、PhpMyAdminで作成して実行せよ。 日本の全市区町村を人口密度が低 1 2023/06/18 19:51
- Access(アクセス) Accessのクエリの結果を、既存のエクセルに追加したい 2 2022/07/31 22:44
- Excel(エクセル) PHPプログラムをエクセルに張り付けると検索ボックスがでてくる! 3 2022/05/08 07:10
- Excel(エクセル) 別シートに毎回異なるデータをコピーする 7 2022/06/24 09:02
このQ&Aを見た人はこんなQ&Aも見ています
-
「環境が人を育てる」って本当?環境によって人格や生き方は本当に変わるのか
環境が人生に与える影響は実際どれほどのものなのか、専門家の田宮由美さんに伺った。
-
JavaScript window.openで開く際、そのwindowの背景色を指定したい
JavaScript
-
単一グループのグループ関数ではありません。
Oracle
-
Selectの中身をfor文で入れる
JavaScript
-
-
4
サブウインドウから親ウインドウのラジオボタンにチェックを入れる
JavaScript
-
5
jsp/Servletの動的に増えるフォーム情報受け取りについて質問です。
Java
-
6
servletからjspへオブジェクトの配列情報を送る方法
Java
-
7
GROUP BYを行った後に結合したい。
Oracle
-
8
『列名 '担当者CD' があいまいです。』
Microsoft ASP
-
9
指定した年月までのデータを取得するSQL文
Oracle
-
10
boolean型のフィールドとゲッターメソッドの命名について
Java
-
11
重複するキーから一番古い年月日のデータのみ取得したい
PostgreSQL
-
12
VBA 連続行データを5行ずつ隣の列に貼り付ける
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
”パラメータ値を TextBox から ...
-
SQL構文を手助けしてください
-
[SQL]重複内容を持つデータから...
-
shellからストアドプロシージャ...
-
MERGE文について
-
ExcelVBAを使って、値...
-
pl/sqlの配列indexについて は...
-
テキストボックスのvalueとtext...
-
DataGridViewで右寄せ左寄せが...
-
Excelで指定した日付から過去の...
-
i=cells(Rows.Count, 1)とi=cel...
-
【Excel VBA】指定行以降をクリ...
-
長音「ー」とマイナス「-」の...
-
VB.NETで DataRow()を利用して...
-
【Excel】指定したセルの名前で...
-
VB.NETでコンボボックスの1行目...
-
Excel VBA、 別ブックの最終行...
-
ExcelのINDEXとMATCH関数でスピ...
-
Excelのプルダウンで2列分の情...
-
VBScriptで数値にコンマを付け...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
”パラメータ値を TextBox から ...
-
[SQL]重複内容を持つデータから...
-
shellからストアドプロシージャ...
-
SQLでlike検索条件を副問い合わ...
-
ビュー(インラインビュー)で...
-
MERGE文について
-
Exp.exeに指定するparfileパラ...
-
データベース
-
ストアドプロシージャでのパラ...
-
バッチからのSQLPlusの実行につ...
-
PLSQLで条件によりSQLを動的に...
-
このような場合のSQLの記述
-
プロシージャーに動的にパラメ...
-
select文でゴミデータを検索し...
-
Oracle8iのUPDATE文
-
ExcelVBAを使って、値...
-
特定のセルが空白だったら、そ...
-
VB.NETで DataRow()を利用して...
-
i=cells(Rows.Count, 1)とi=cel...
-
【Excel VBA】指定行以降をクリ...
おすすめ情報