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

Вниз

Построение запросов и поиск по полям   Найти похожие ветки 

 
erika ©   (2005-07-14 14:57) [0]

Здравствуйте!

У меня IB. Проблема заключается  в  следующем:  
* три таблицы - клиент (РК INK)
             - билет  (РК IDK, FK INK)
             - покупки (РК ISL, FK IDK),
которые свзаны соответсвенно клиент -> билет -> покупки
* обсновной таблицей является клиент, у  которого может быть несколько книжек и определенное количество покупок по каждой из них

* формируется запрос

select * from <клиент>
inner join <билет> on <клиент>.ink= <билет>.ink
inner join <покупка> on <билет>.idk = <покупка>.idk
where <покупка>.nombers <=5
order by <билет>.DKNOM, <билет>.DKP, <покупка>.nombers

который выбирает из базы всех клиентов с количеством покупок по книжке не более 5% ( в  результате получается ококло 70500 позиций)

Вопросы:
1. Почему  формирование запроса выполняется в течении 3-5 минут (для пользователя это слишком долго)?
2.Поиск по набору данных как при использовании  IBTable (если запрос сопоставляется  с VIEW), так и при использовании IBDATASET (если запрос прописывается  в SelectSQL) осуществляется  с  существенной задержкой (поле поиска не является PK или FK); как можно ускорить поиск?

Заранее благодарна.


 
Val ©   (2005-07-14 15:00) [1]

1.видать, все дело в индексах.
2.а нельзя ли перекинуть условие where and"ом в последний join?


 
evvcom ©   (2005-07-14 15:03) [2]


> как можно ускорить поиск?

построить индекс по <покупка>.nombers


 
erika ©   (2005-07-14 15:11) [3]

поси производится по полям <билет>.DKNOM, <билет>.DKP, если использую IBTable, то при поиске прописываю IBTable.IndexFieldName := DKNOM, а как построить index в IB (работаю через IBExpert),  я  не знаю


 
Val ©   (2005-07-14 15:13) [4]

см.sql help - create index.
а в IBExpert это интуитивно понятно :)


 
erika ©   (2005-07-14 15:19) [5]

поиск производится по полям <билет>.DKNOM, <билет>.DKP, если использую IBTable, то при поиске прописываю IBTable.IndexFieldName := DKNOM, а как построить index в IB (работаю через IBExpert),  я  не знаю


 
erika ©   (2005-07-14 15:26) [6]

create index - куда идти что бы  сформировать, где  и  чего нажимать (если можно???)



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

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

Наверх




Память: 0.48 MB
Время: 0.053 c
4-1120281673
Lex_!
2005-07-02 09:21
2005.08.28
SpeechApi - не говорит по русски


14-1122362577
ANB
2005-07-26 11:22
2005.08.28
Теория Дарвина - жива или умерла ?


14-1123159211
oldman
2005-08-04 16:40
2005.08.28
Хотел в ветку про Динамо написать, но создам новую...


1-1123600501
_Андрей
2005-08-09 19:15
2005.08.28
Создание формы в потоке, функция которого находится в DLL


4-1120650731
Cosinus
2005-07-06 15:52
2005.08.28
Почему из-за нижеследующего кода в ловушке, она не работает?