Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2003.07.17;
Скачать: CL | DM;

Вниз

---|Ветка была без названия|---   Найти похожие ветки 

 
McSimm2   (2003-06-25 15:25) [0]

Как можно соптимизировать запрос?
Такая ситуация, мне нужно после where указывать равенство 3 полей из одного и того же запроса:

...
WHERE n_lc IN (SELECT k.n_lc
FROM table1 k, table2.dom d
WHERE (d.ulica = k.ulica(+) AND d.dom = k.dom(+))
AND UPPER (k.ulica) LIKE "%XXX%")
AND jeu IN (SELECT k.jeu
FROM table1 k, table2.dom d
WHERE (d.ulica = k.ulica(+) AND d.dom = k.dom(+))
AND UPPER (k.ulica) LIKE "%XXX%")
AND rajon IN (SELECT k.rajon
FROM table1 k, table2.dom d
WHERE (d.ulica = k.ulica(+) AND d.dom = k.dom(+))
AND UPPER (k.ulica) LIKE "%XXX%")

Как нибудь можно это сократить ???


 
kravchuk ©   (2003-06-25 15:34) [1]

попробуй :


FROM ...., table1 k, table2.dom d

WHERE
(d.ulica = k.ulica(+) AND d.dom = k.dom(+))
AND UPPER (k.ulica) LIKE "%XXX%")
and n_lc=k.n_lc
and jeu =k.jeu
and rajon=k.rajon


 
McSimm2   (2003-06-25 15:41) [2]

Не,- так нельзя, смысл в том,что в селекте у меня идут только вычисляемые поля и если во внешний where вынести условия из вложенных запросов - то основной запрос не пройдёт, т.к. не сможет тогда посчитать сумму...

Select sum(t.sum_field1) as sum1, sum(t.sum_field2) as sum2
from table0 t
WHERE t.n_lc IN (SELECT k.n_lc
FROM table1 k, table2.dom d
WHERE (d.ulica = k.ulica(+) AND d.dom = k.dom(+))
AND UPPER (k.ulica) LIKE "%XXX%")
AND t.jeu IN (SELECT k.jeu
FROM table1 k, table2.dom d
WHERE (d.ulica = k.ulica(+) AND d.dom = k.dom(+))
AND UPPER (k.ulica) LIKE "%XXX%")
AND t.rajon IN (SELECT k.rajon
FROM table1 k, table2.dom d
WHERE (d.ulica = k.ulica(+) AND d.dom = k.dom(+))
AND UPPER (k.ulica) LIKE "%XXX%")


 
roottim   (2003-06-25 15:43) [3]

ну вообще такой запрос должен отработать
WHERE (n_lc, jeu, rajon)
IN (SELECT k.n_lc, k.jeu, k.rajon
FROM table1 k, table2.dom d
WHERE (d.ulica = k.ulica(+) AND d.dom = k.dom(+))
AND UPPER (k.ulica) LIKE "%XXX%")


 
Sandman25 ©   (2003-06-25 15:44) [4]

Еще можно попробовать EXISTS, если есть опасность повторений.


 
McSimm2   (2003-06-25 15:45) [5]

roottim (25.06.03 15:43)

Ага - вот я это и имел в виду - можно ли так делать ??? Мне просто это очень сложно проверить - результат запроса -большие и большие цифры....


 
McSimm2   (2003-06-25 15:45) [6]

Sandman25 © (25.06.03 15:44)

Что значит опасность повторений ?


 
roottim   (2003-06-25 15:47) [7]

МОЖНО!


 
Sandman25 ©   (2003-06-25 15:53) [8]

По варианту kravchuk © (25.06.03 15:34)
если в таблицах tabl1 И table2.dom есть повторяющиеся строки (дубликаты), то связывание произойдет несколько раз (вместо 1). В таком случае лучше использовать
...
FROM T
...
AND EXISTS
(SELECT *
FROM table1 k, table2.dom d
WHERE
d.ulica = k.ulica(+) AND d.dom = k.dom(+))
AND UPPER (k.ulica) LIKE "%XXX%"
and T.n_lc=k.n_lc
and T.jeu =k.jeu
and T.rajon = k.rajon
)

and rajon=k.rajon



 
McSimm2   (2003-06-25 15:56) [9]

roottim (25.06.03 15:47)

Отлично работает !!!


 
Sandman25 ©   (2003-06-25 15:58) [10]

Нижняя строка "and rajon=k.rajon"
по ошибке редактирования прошла.


 
McSimm2   (2003-06-25 16:06) [11]

Sandman25 © (25.06.03 15:58)

а что в данном случае exists делает ?


 
Sandman25 ©   (2003-06-25 16:56) [12]

Проверяет, что в table1 и table2.dom есть соответсвующая инфо. При этом не важно, сколько именно строк удовлетворяют условию связи, и исходные данные будут суммироваться только 1 раз (если удовлетворяют условию связи).



Страницы: 1 вся ветка

Текущий архив: 2003.07.17;
Скачать: CL | DM;

Наверх




Память: 0.49 MB
Время: 0.018 c
14-55746
Дмитрий К.К.
2003-07-03 06:12
2003.07.17
Именинники 3 июля


3-55397
Smalik
2003-06-23 13:56
2003.07.17
Сортировка в Grid e


3-55404
Status_I
2003-06-22 19:47
2003.07.17
Ввод функции


7-55878
Fakir
2003-05-05 15:44
2003.07.17
Свойства принтера


8-55669
Арм
2003-03-25 02:50
2003.07.17
Midi