teratail header banner
teratail header banner
質問するログイン新規登録

回答編集履歴

3

マニュアルについて追記

2019/05/01 00:20

投稿

Y.H.
Y.H.

スコア7918

answer CHANGED
@@ -7,6 +7,7 @@
7
7
  サブクエリーの結果は全件取得されています。
8
8
 
9
9
  [実行計画(実行プラン)](https://dev.mysql.com/doc/refman/5.6/ja/explain-output.html)を確認してみないと正確な事は判りませんが、以下と同等な実行がなされたのではないでしょうか?
10
+ ※本質問のような疑問に対しては[実行計画(実行プラン)](https://dev.mysql.com/doc/refman/5.6/ja/explain-output.html)を確認すると解ることが多いです。使用方法および結果の見方を覚えておかれると役立つと思います。(また、SQLの性能改善には利用必須の機能となります)
10
11
 
11
12
  親のselect文のテーブル`player p`に対してサブクエリーの`where p.teamNo = 2 and p.uniformNo=5`(キー項目による絞り込み)が評価され1件が抽出ます。
12
13
  このレコードがサブクエリー(結果:player全件)に存在するため、sql全体として1件抽出される結果となります。
@@ -26,8 +27,8 @@
26
27
  );
27
28
  ```
28
29
 
29
- 本質問のような疑問対しては[実行計画(実行プラン)](https://dev.mysql.com/doc/refman/5.6/ja/explain-output.html)を確認すると解ることが多す。
30
- 使用方法および結果見方を覚えおかれると役立と思います。(また、SQL性能改善には利用必須の機能なります)
30
+ ※ [saziさん回答(追記2)](https://teratail.com/questions/186500#reply-277172)にも記載されていますが、このようなMySQLの動作関する事柄についてはMySQLのマニュアル「[8.2.1.18.4 EXISTS 戦略によるサブクエリーの最適化](https://dev.mysql.com/doc/refman/5.6/ja/subquery-optimization.html#subquery-optimization-with-exists)」に記載されてす。
31
+ 部分来限らず、MySQLについの動作原理について疑問を解消(または理解を深める)ならば公式マニュアルを読まれるこをお勧めします
31
32
 
32
33
 
33
34
  ----

2

修正

2019/05/01 00:20

投稿

Y.H.
Y.H.

スコア7918

answer CHANGED
@@ -1,6 +1,7 @@
1
1
  追記
2
2
 
3
3
  (コメントより)
4
+ > 仕組みを理解したくて質問させていただきました
4
5
  > inにした場合の結果が一件だけなのでしょうか
5
6
 
6
7
  サブクエリーの結果は全件取得されています。

1

コメントを受けて追記

2019/04/30 23:59

投稿

Y.H.
Y.H.

スコア7918

answer CHANGED
@@ -1,3 +1,36 @@
1
+ 追記
2
+
3
+ (コメントより)
4
+ > inにした場合の結果が一件だけなのでしょうか
5
+
6
+ サブクエリーの結果は全件取得されています。
7
+
8
+ [実行計画(実行プラン)](https://dev.mysql.com/doc/refman/5.6/ja/explain-output.html)を確認してみないと正確な事は判りませんが、以下と同等な実行がなされたのではないでしょうか?
9
+
10
+ 親のselect文のテーブル`player p`に対してサブクエリーの`where p.teamNo = 2 and p.uniformNo=5`(キー項目による絞り込み)が評価され1件が抽出ます。
11
+ このレコードがサブクエリー(結果:player全件)に存在するため、sql全体として1件抽出される結果となります。
12
+
13
+ ```
14
+ (
15
+ select teamName , positionName ,uniformNo ,playerName
16
+ from player
17
+ where teamNo = 2 and uniformNo=5
18
+ ) p
19
+ join team using(teamNo)
20
+ join position1 using(PositionNo)
21
+ where positionNo in
22
+ (
23
+ select positionNo
24
+ from player
25
+ );
26
+ ```
27
+
28
+ 本質問のような疑問に対しては[実行計画(実行プラン)](https://dev.mysql.com/doc/refman/5.6/ja/explain-output.html)を確認すると解ることが多いです。
29
+ 使用方法および結果の見方を覚えておかれると役立つと思います。(また、SQLの性能改善には利用必須の機能となります)
30
+
31
+
32
+ ----
33
+
1
34
  このサブクエリーですが、Playerとの結合がないのでplayerテーブルの全件が取得されます。
2
35
 
3
36
  ```