回答編集履歴

1

訂正を追記

2017/01/10 05:51

投稿

KiyoshiMotoki
KiyoshiMotoki

スコア4791

test CHANGED
@@ -91,3 +91,91 @@
91
91
  ORDER BY total DESC;
92
92
 
93
93
  ```
94
+
95
+ # 訂正
96
+
97
+ UNION 句だと値が重複している行が削除されてしまうため、UNION ALL句を使用する必要がありました。
98
+
99
+ [https://dev.mysql.com/doc/refman/5.6/ja/union.html](https://dev.mysql.com/doc/refman/5.6/ja/union.html)
100
+
101
+ > UNION のデフォルトの動作では、重複した行が結果から削除されます。(中略)オプションの ALL キーワードを指定すると、重複した行の削除は実行されず、その結果には、すべての SELECT ステートメントからの一致するすべての行が含まれます。
102
+
103
+ ```sql
104
+
105
+ SELECT ranking.user_id, SUM(ranking.creds) AS total
106
+
107
+ FROM (
108
+
109
+ (
110
+
111
+ SELECT c.user_id, c.creds
112
+
113
+ FROM
114
+
115
+ ((wp_2_myCRED_log c
116
+
117
+ LEFT JOIN wp_2_comments o ON c.ref_id = o.comment_ID)
118
+
119
+ INNER JOIN wp_2_term_relationships r ON o.comment_post_ID = r.object_id)
120
+
121
+ INNER JOIN wp_2_terms t ON r.term_taxonomy_id = t.term_id
122
+
123
+ WHERE
124
+
125
+ t.name = "カテゴリ1"
126
+
127
+ )
128
+
129
+ UNION ALL
130
+
131
+ (
132
+
133
+ SELECT c.user_id, c.creds
134
+
135
+ FROM
136
+
137
+ (((wp_2_myCRED_log c
138
+
139
+ LEFT JOIN wp_2_posts p ON c.ref_id = p.ID)
140
+
141
+ INNER JOIN wp_2_postmeta m ON p.ID = m.post_id)
142
+
143
+ INNER JOIN wp_2_term_relationships r ON m.meta_value = r.object_id)
144
+
145
+ INNER JOIN wp_2_terms t ON r.term_taxonomy_id = t.term_id
146
+
147
+ WHERE
148
+
149
+ t.name = "カテゴリ1"
150
+
151
+ )
152
+
153
+ UNION ALL
154
+
155
+ (
156
+
157
+ SELECT c.user_id, c.creds
158
+
159
+ FROM
160
+
161
+ ((wp_2_myCRED_log c
162
+
163
+ LEFT JOIN wp_2_posts p ON c.ref_id = p.ID)
164
+
165
+ INNER JOIN wp_2_term_relationships r ON p.ID = r.object_id)
166
+
167
+ INNER JOIN wp_2_terms t ON r.term_taxonomy_id = t.term_id
168
+
169
+ WHERE
170
+
171
+ t.name = "カテゴリ1"
172
+
173
+ )
174
+
175
+ ) AS ranking
176
+
177
+ GROUP BY ranking.user_id
178
+
179
+ ORDER BY total DESC;
180
+
181
+ ```