Forum Webscript.Ru
Общие => Базы данных => Тема начата: Uzver от 01 Апреля 2008, 15:18:14
-
всем доброго дня
имеется запрос вида (возможно несколько громоздкий пример но суть думаю будет понятна):
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 записей. тотже самый запрос но разбитый на два, тоесть сначала ОТДЕЛЬНО выполняем вложенный запрос а потом с его результатами выполняем основной, выполняется уже за десятые доли секунды. собственно вопрос, есть-ли другие пути чтобы получить тот-же самый результат одним запросом но при этом не ждать несколько секунд на его выполнение ?
-
в подзапросе 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\'
Это как вариант но можно и по другому
-
спасибо, пошел искать учебники ((
-
или может даже так
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 обрежется до иннер джоина
нужно смотреть план выполнения запроса