我正在运行这个SQL查询并且它给了我一个错误,当我重新安排列并使DISTINCT k.Column_1首先它起作用但然后永远运行并且似乎是一个昂贵的。我该如何纠正,优化等?
SELECT
k.Column_2, DISTINCT k.Column_1, s.Column_3, s.Column_4, s.Column_5, s.Column_6, s.Column_7,
s.Column_8, s.Column_9, s.Column_10, s.Column_11, t.Column_5,
t.Column_6, t.Column_7, t.Column_8, t.Column_9, t.Column_10,
t.Column_11, r.Column_3,
p.Column_2, p.Column_3, p.Column_4, p.5, p.Column_6, p.Column_7, p.Column_8, p.Column_9
FROM table_1 k
LEFT JOIN table_2 s
ON k.Column_1 = s.Column_1
LEFT JOIN table_3 t
ON k.Column_1 = t.Column_1
LEFT table_4 r
ON k.Column_1 = r.Column_1
LEFT JOIN table_5 p
ON k.Column_1 = p.Column_1
我现在正在运行这个已编辑的SQL查询,它正在运行,我希望尽可能优化它。
Column_1是索引。
SELECT DISTINCT k.Column_1, k.MONTH,
SUM(s.Column_3) Column_3,
SUM(s.Column_4) Column_4,
SUM(s.Column_5) Column_5,
SUM(s.Column_6) Column_6,
SUM(s.Column_7) Column_7,
SUM(s.Column_8) Column_8,
SUM(s.Column_9) Column_9,
SUM(s.Column_10) Column_10,
SUM(s.Column_11) Column_11,
SUM(t.Column_5) Column_5,
SUM(t.Column_6) Column_6,
SUM(t.Column_7) t.Column_7,
SUM(t.Column_8) Column_8,
SUM(t.Column_9) Column_9,
SUM(t.Column_10) Column_10,
SUM(t.Column_11) Column_11,
SUM(r.Column_3) Column_3,
SUM(p.Column_2) Column_2,
SUM(p.Column_3) Column_3,
SUM(p.Column_4) Column_4,
SUM(p.Column_5) Column_5,
SUM(p.Column_6) Column_6,
SUM(p.Column_7) Column_7,
SUM(p.Column_8) Column_8,
SUM(p.Column_9) Column_9
FROM table_1 k
LEFT JOIN table_2 s
ON k.Column_1 = s.Column_1
LEFT JOIN table_3 t
ON k.Column_1 = t.Column_1
LEFT table_4 r
ON k.Column_1 = r.Column_1
LEFT JOIN table_5 p
ON k.Column_1 = p.Column_1
GROUP BY k.Column_1, k.MONTH
答案 0 :(得分:2)
DISTINCT k.Column_1,
不正确且语法错误。 distinct
关键字适用于您要提取的整个属性集,而不是每列。
应该是
SELECT DISTINCT k.Column_2, k.Column_1, s.Column_3, s.k.Column_4, s.Column_5, ....
答案 1 :(得分:0)
要考虑的一件大事是,连接可以返回更多组合,然后您可能会期望。例如,拿这两个表。
Table_A Table_B
+-----+ +-----+
|Var_A| |Var_B|
+-----+ +-----+
| 2 | | 2 |
| 2 | | 2 |
| 2 | | 4 |
| 4 | +-----+
+-----+
如果你跑
SELECT
*
FROM table_a
LEFT JOIN table_b
ON table_a.var_a = table_b.var_b
你会得到这个烂摊子,因为它匹配var_a和var_b之间每个可能的值组合
+-----+-----+
|Var_A|Var_B|
+-----+-----+
| 2 | 2 |
| 2 | 2 |
| 2 | 2 |
| 2 | 2 |
| 2 | 2 |
| 2 | 2 |
| 4 | 4 |
+-----+-----+
为避免遇到此问题,请加入更多字段,使您的联接更具限制性,即使您最终不会使用它们。