У меня есть действительный MySQL Query, который выбирает последний процент заполнения таблицы из каждого сообщества, введенный в моей БД, но, похоже, сканирует весь БД записей, поскольку время поиска занимает примерно 3-4 секунды.
С подробностями, представленными в нижеприведенном запросе, может ли кто-нибудь предоставить мне более быстрый/лучший способ найти последнее временное поле для каждого сообщества? - Мне нужен запрос, чтобы выбрать каждое введенное сообщество с самой последней отметкой времени, но ограничение для каждого выбранного сообщества должно быть 1 (это означает, что сообщество с именем "Test Community" будет иметь сотни представлений, но мне нужна последняя введенная отметка времени, с тем же выбором для каждого сообщества, внесенного в таблицу)
SELECT t1.reportID, t1.communityID, t1.region, t1.percentOccupied,
t1.TIMESTAMP, Communities.fullName
FROM NightlyReports t1
INNER JOIN Communities On t1.communityID = Communities.communityID
WHERE t1.TIMESTAMP = ( SELECT MAX( TIMESTAMP ) FROM NightlyReports WHERE
t1.communityID = NightlyReports.communityID )
AND t1.region = 'GA' ORDER BY percentOccupied DESC
По моему опыту, коррелированные подзапросы часто имеют довольно низкую производительность; попробуйте это вместо этого:
SELECT t1.reportID, t1.communityID, t1.region, t1.percentOccupied
, t1.TIMESTAMP, Communities.fullName
FROM NightlyReports AS t1
INNER JOIN Communities ON t1.communityID = Communities.communityID
INNER JOIN (
SELECT communityID, MAX( TIMESTAMP ) AS lastTimestamp
FROM NightlyReports
WHERE region = 'GA'
GROUP BY communityID
) AS lastReports ON t1.communityID = lastReports.communityID
AND t1.TIMESTAMP = lastReports.lastTimestamp
WHERE t1.region = 'GA'
ORDER BY percentOccupied DESC
Ваш запрос в порядке. Для этого запроса (который переписан немного):
SELECT nr.reportID, nr.communityID, nr.region, nr.percentOccupied,
nr.TIMESTAMP, c.fullName
FROM NightlyReports nr INNER JOIN
Communities c
ON nr.communityID = c.communityID
WHERE nr.TIMESTAMP = (SELECT MAX(nr2.TIMESTAMP)
FROM NightlyReports nr2
WHERE nr.communityID = nr2.communityID
) AND
nr.region = 'GA'
ORDER BY percentOccupied DESC;
Вы хотите индексы:
NightlyReports(region, timestamp, communityid)
NightlyReports(communityid, timestamp)
Communities(communityID)
(это может уже существовать)Коррелированный подзапрос сам по себе не является проблемой.