查询MySQL中的自联接

时间:2014-04-10 09:44:41

标签: mysql

我有一个获得正确结果的查询,但是获取输出需要5.5秒。有没有其他方法可以为此编写查询 -

SELECT metricName, metricValue 
FROM Table sm  
WHERE createdtime = (
    SELECT MAX(createdtime) 
    FROM Table b 
    WHERE sm.metricName = b.metricName 
    AND b.sinkName='xx' 
) 
AND sm.sinkName='xx'

1 个答案:

答案 0 :(得分:2)

在您的代码中,必须为外部查询的每个结果行运行子选择,这应该非常昂贵。相反,您可以在单独的查询中选择过滤器数据并相应地加入:

SELECT `metricName`, `metricValue` FROM Table sm 
INNER JOIN (SELECT max(`createdtime`) AS `maxTime, `metricName` from Table b WHERE b.sinkName='xx' GROUP BY `metricName` ) filter
  ON (sm.`createdtime` = filter.`maxTime`) AND ( sm.`metricName` = filter.`metricName`)
WHERE sm.sinkName='xx'