回答編集履歴

1

回答の補足と文言の訂正

2021/08/24 10:59

投稿

mayu-
mayu-

スコア335

test CHANGED
@@ -81,3 +81,93 @@
81
81
   
82
82
 
83
83
  参考書の記載どおりになりました。
84
+
85
+
86
+
87
+ ### 追記
88
+
89
+ k.fujisawaさんのご指摘を受けて回答を見返すと
90
+
91
+ 先の私の回答、```一次元配列(集合)```という表現は確かに変でした。
92
+
93
+
94
+
95
+ インラインビューを用い、多段クエリにしたら
96
+
97
+
98
+
99
+ > case文によって疑似的なテーブルが作成されるのでしょうか?
100
+
101
+
102
+
103
+ の「 疑似的なテーブルが作成される 」に近い```SQL```になりそうですね。
104
+
105
+
106
+
107
+ ```SQL
108
+
109
+ SELECT sex
110
+
111
+ , sum(k) Kanagawa
112
+
113
+ , sum(o) Osaka
114
+
115
+ , sum(t) Tokyo
116
+
117
+ FROM
118
+
119
+ (
120
+
121
+ SELECT sex
122
+
123
+ , case user_place when 'Kanagawa' then 1 else 0 end k
124
+
125
+ , case user_place when 'Osaka' then 1 else 0 end o
126
+
127
+ , case user_place when 'Tokyo' then 1 else 0 end t
128
+
129
+ FROM master_customer
130
+
131
+ ) q
132
+
133
+ GROUP BY sex ;
134
+
135
+ ```
136
+
137
+
138
+
139
+ この```SQL```だとどうでしょうか。
140
+
141
+ インラインビュー```q```は「 疑似的なテーブル 」になっており、
142
+
143
+ 結果セットは以下のようになります。
144
+
145
+
146
+
147
+ | sex | k | o | t |
148
+
149
+ |:--|:--:|--:|--:|
150
+
151
+ | M | 1 | 0 | 0 |
152
+
153
+ | M | 0 | 1 | 0 |
154
+
155
+ | M | 0 | 0 | 1 |
156
+
157
+ | M | 1 | 0 | 0 |
158
+
159
+ | M | 0 | 0 | 1 |
160
+
161
+ | W | 1 | 0 | 0 |
162
+
163
+ | W | 0 | 0 | 1 |
164
+
165
+ | W | 0 | 0 | 1 |
166
+
167
+ | W | 0 | 1 | 0 |
168
+
169
+ | W | 0 | 1 | 0 |
170
+
171
+ | W | 0 | 0 | 1 |
172
+
173
+ | W | 0 | 0 | 1 |