Главная страница
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.023 c
14-1123451681
uw
2005-08-08 01:54
2005.08.28
Всем кто сейчас пьет пиво.


9-1112773901
rainKM
2005-04-06 11:51
2005.08.28
Random (Pascal)


1-1123675405
Steepesson
2005-08-10 16:03
2005.08.28
Компонент TTreeView


14-1123229357
ПЛОВ
2005-08-05 12:09
2005.08.28
Сколько осталось жить флопикам?


8-1113997439
Comrade
2005-04-20 15:43
2005.08.28
Просмотр Видио файла