我有一个获得正确结果的查询,但是获取输出需要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'
答案 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'