我该如何纠正这个SQL查询&优化它?

时间:2017-06-28 21:09:13

标签: sql database analytics business-intelligence database-administration

我正在运行这个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

2 个答案:

答案 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  |
+-----+-----+

为避免遇到此问题,请加入更多字段,使您的联接更具限制性,即使您最终不会使用它们。