Главная страница
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-55851
Тих
2003-07-02 02:17
2003.07.17
Снова шлют ерунду


14-55792
Dimedrol
2003-06-30 16:53
2003.07.17
Как передать переменную в FastReport ?


3-55386
Free_User
2003-06-23 12:17
2003.07.17
Disconnect


14-55747
VEG
2003-07-02 22:58
2003.07.17
Кто-нибудь разрабатывал один проект более 2- лет??7


1-55638
R
2003-07-04 08:10
2003.07.17
Вырезать кусок изображения.