Общие > Базы данных
вложения в мускуле
(1/1)
Uzver:
всем доброго дня
имеется запрос вида (возможно несколько громоздкий пример но суть думаю будет понятна):
SELECT * FROM `news`,`material` WHERE `news`.`materialID` = `material`.`materialID` and `news`.`newsDir` IN (SELECT `page`.`pageID` FROM `page`,`dir_page`,`dir`,`material` WHERE `dir`.`dirID` = \'11\' and `dir`.`dirID` = `dir_page`.`dirID` and `page`.`pageID` = `dir_page`.`pageID` and `dir_page`.`dirpPublish` = \'on\' and `page`.`materialID` = `material`.`materialID` and `material`.`materialPublish` = \'on\') ORDER by `news`.`newsDate` DESC
время выполнения запроса (при отключенном кешировании) порядка 2!!! секунд. в базе примерно 40 000 записей. тотже самый запрос но разбитый на два, тоесть сначала ОТДЕЛЬНО выполняем вложенный запрос а потом с его результатами выполняем основной, выполняется уже за десятые доли секунды. собственно вопрос, есть-ли другие пути чтобы получить тот-же самый результат одним запросом но при этом не ждать несколько секунд на его выполнение ?
ravshaniy:
в подзапросе dir - не нужно вообще. и матириал используете дважды, нет необходимости. Отсюда подзапрос будет таким:
--- Код: ---SELECT `page`.`pageID` FROM page
INNER JOIN dir_page ON page.`pageID` = `dir_page`.`pageID`
WHERE dir_page.dirID = \'11\'
and `dir_page`.`dirpPublish` = \'on\'
--- Конец кода ---
ну а сам запрос нужно делать скорее так:
--- Код: ---SELECT * FROM `news` n
INNER JOIN (
SELECT `page`.`pageID` FROM page
INNER JOIN dir_page ON page.`pageID` = `dir_page`.`pageID`
WHERE dir_page.dirID = \'11\'
and `dir_page`.`dirpPublish` = \'on\'
) pi ON n.newsDir = pi.pageID
INNER JOIN material m ON n.`materialID` = m.`materialID`
WHERE m.materialPublish` = \'on\'
--- Конец кода ---
Это как вариант но можно и по другому
Uzver:
спасибо, пошел искать учебники ((
ravshaniy:
или может даже так
--- Код: ---SELECT * FROM `news` n
INNER JOIN (
SELECT `page`.`pageID` FROM page
INNER JOIN dir_page ON page.`pageID` = `dir_page`.`pageID`
WHERE dir_page.dirID = \'11\'
and `dir_page`.`dirpPublish` = \'on\'
) pi ON n.newsDir = pi.pageID
INNER JOIN (
SELECT * FROM material WHERE materialPublish = \'on\'
) m ON n.`materialID` = m.`materialID`
--- Конец кода ---
Так может быть выигрыш за счет того что таблица material обрежется до иннер джоина
нужно смотреть план выполнения запроса
Навигация
Перейти к полной версии