
SELECT a.num b.num FROM
サブクエリA(いろんな処理 WHERE a_id=ANY(サブクエリC(いろんな処理)) ) AS a,
サブクエリB(いろいろ処理 WHERE b_id=ANY(サブクエリD(いろんな処理)) ) AS b
このような処理をしているのですが、サブクエリCとサブクエリDは一字一句違わない全く同じ処理をしています。
2回全く同じ処理をするのは処理コストが無駄にかかりますし、同じ内容を示す表記が2度出てくるのは保守性も悪くします。
サブクエリCとDを共通化して一つにまとめる方法はありますでしょうか。
No.3ベストアンサー
- 回答日時:
これって合計じゃなくて単にcount処理をフラグやグレードを指定して取っているだけですね。
//準備
create table A (id int,flag tinyint);
create table B (id int,grade tinyint);
create table C (id int,val int);
insert into A values(1,0),(2,1),(3,0),(4,1),(5,1),(6,0),(7,0);
insert into B values(1,0),(2,0),(3,2),(4,2),(5,0),(6,0),(7,0);
insert into C values(1,10),(2,20),(3,30),(4,40),(5,50),(6,60),(7,70);
//非効率SQL
SELECT num_a, num_b FROM
(SELECT SUM(IF(flag=0, 1, 0)) AS num_a FROM A
WHERE id=ANY(SELECT id FROM C WHERE val<=50)) AS sub_a,
(SELECT SUM(IF(grade=2, 1, 0)) AS num_b FROM B
WHERE id=ANY(SELECT id FROM C WHERE val<=50)) AS sub_b
//調整後
SELECT count(flag) as num_a,count(grade) as num_b
FROM C
LEFT JOIN A on C.id=A.id and flag=0
LEFT JOIN B on C.id=B.id and grade=2
WHERE val<=50;
No.2
- 回答日時:
>joinについてはどういう風にやるのかもう少し詳しくお願いできますでしょうか。
うーん、元のSQLが微妙なのでなんとも言えません
見た感じサブクエリC(D)によりAとBを抽出して結合し列記するという命題であれば
たとえばサブクエリAで得られるnumが(1,2)サブクエリBで得られるnumが(1,3)だと
このクエリで抽出されるデータは
num_a num_b
1 1
2 1
1 3
2 3
のようにA×Bの冗長なデータになりますがほんとにそういう考え方でよいのですか?
この回答への補足
問題のソースをできる限り簡素化して具体的な形が見えるようにしてみました。
SELECT a.totalNum, b.totalNum FROM
(SELECT SUM(IF(flag=0, 1, 0)) AS totalNum FROM x
WHERE id=ANY(SELECT id FROM zzz WHERE 条件)) AS a,
(SELECT SUM(IF(grade=2, 1, 0)) AS totalNum FROM y
WHERE id=ANY(SELECT id FROM zzz WHERE 条件)) AS b
比較するために二つの合計数(a.totalNum、b.totalNum)を得るものです。
ANYの中身はどちらも完全に同じクエリです。
いかがでしょうか。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- SQL Server SQLについて WITH句とサブクエリの使い分けは何でしょうか? 処理速度に違いがありますか? 1 2022/11/21 11:10
- Oracle Oracleですがsqlで質問です。 サブクエリ内で番号というカラムで昇順の1レコード目を取得したい 3 2023/05/22 10:02
- SQL Server 自己相関サブクエリと自己結合の違いを教えてください 1 2023/07/15 10:58
- Visual Basic(VBA) ExcelからAccessのテーブルに書き込む時に時間がかかる 1 2022/10/14 20:38
- Visual Basic(VBA) vbaのエラー対応(実行時エラー7:メモリが不足しています) 4 2023/04/24 00:20
- Visual Basic(VBA) 【前回の続き続きです、ご教示ください】VBAの記述方法がわかりません。 2 2022/08/24 20:49
- Excel(エクセル) Excel VBAどこが間違ってますか? 4 2023/07/17 10:04
- Visual Basic(VBA) VBAのユーザーフォームのテキストボックスに入力制限をしたい 6 2022/11/15 08:28
- C言語・C++・C# C言語:数値の桁数指定についての質問です。 8 2022/05/26 23:53
- Visual Basic(VBA) ユーザーフォーム「frm_基本❶」を立ち上げると新規で入力する行数を右下のNoとして表示しています。 1 2023/03/16 19:02
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
複数テーブルのGROUP BY の使い...
-
mysqlについて
-
フリーマーケット!
-
ローカルルーターモードとは
-
[SQLServer] テーブル名からカ...
-
MSDNselectしながらWHileでまわ...
-
テーブル名を省略して「h.id」...
-
製品の最安店舗を取りたい。
-
MySQLの抽出について
-
PL/SQLの変数について
-
Dell Latitude C600に合うメモ...
-
このSQL文の意味を教えてくださ...
-
SQLとC#connectについて
-
SQL Server を使っています。SQ...
-
SQL文で、一部一致した列だけ抽出
-
INSERT時の大小比較を含む重複...
-
カラム情報取得方法
-
SQLServerでのデータディクショ...
-
SQLについて質問します
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
エクセルの関数について教えて...
-
sqlで、600行あるテーブルを100...
-
select文のwhere句に配列を入れ...
-
SQLにて特定の文字を除いた検索...
-
WordpressのContact form 7でzi...
-
SQLサーバから、項目の属性(型...
-
VIEWの元のテーブルのindexって...
-
クエリ表示と、ADOで抽出したレ...
-
マイクラPC版のコマンドで効率...
-
【Transact-sql】 execの結果を...
-
SQL Left Join で重複を排除す...
-
エラー 1068 (42000): 複数の主...
-
[MySQL] UNIQUE制約の値を更新...
-
inner joinをすると数がおかし...
-
1テーブル&複数レコードの更新...
-
Access パラメータクエリをcsv...
-
期間の重複を調べるSQL文につい...
-
Unionした最後にGROUP BYを追加...
-
Updateの複数テーブル条件時のL...
おすすめ情報