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

Вниз

Поиск по индексированному полю типа integer   Найти похожие ветки 

 
DancerMan ©   (2006-04-10 10:57) [0]

Добрый день!

В таблице есть поле ID - integer. Есть уникальный индекс по этому полу.
Данные из таблицы получаю с помощью IBQuery. (order by ID)
Каким способом быстрее всего перейти на запись с заданным номером ID?


 
Виталий Панасенко   (2006-04-10 10:59) [1]

select * from table where ID=:ID_VALUE


 
DancerMan ©   (2006-04-10 11:01) [2]


> Виталий Панасенко   (10.04.06 10:59) [1]

Мне нужно не выбрать запись с данным номером, а в открытом наборе данных перейти на нее.


 
Desdechado ©   (2006-04-10 11:05) [3]

Locate


 
Savek   (2006-04-10 11:05) [4]

Locate


 
DancerMan ©   (2006-04-10 11:08) [5]


> Desdechado ©   (10.04.06 11:05) [3]


> Savek   (10.04.06 11:05) [4]

Мне кажется функция Locate работает слишком медленно. В таблице всего лишь 40000 записей, а поле индексированно. Мой Pentium 1,7 /512 задумывается где-то на 1-2 секунды.
Может есть более быстрый вариант перехода?


 
Anatoly Podgoretsky ©   (2006-04-10 11:09) [6]

Зачем нужно выбирать ненужные записи с сервера?


 
Sergey13 ©   (2006-04-10 11:11) [7]

2[5] DancerMan ©   (10.04.06 11:08)
> В таблице всего лишь 40000 записей, а поле индексированно. Мой Pentium 1,7 /512 задумывается где-то на 1-2 секунды.
Это потому, что ты не задумался оптимизировать запрос. Работа методами Парадокса/ДиБейса, не всегда хороша для SQL-серверов.


 
DancerMan ©   (2006-04-10 11:47) [8]


> Anatoly Podgoretsky ©   (10.04.06 11:09) [6]
> Зачем нужно выбирать ненужные записи с сервера?

У меня есть компонент, который отображает данные в виде дерева. Я эти данные сразу и выбираю.
Если выборку этих данных написать в  виде хранимой процедуры, это ускорит процесс? Или все-равно надо обрабатьвать каждое раскрытие ветки и выбирать данные по необходимости?


 
Desdechado ©   (2006-04-10 11:55) [9]

> Или все-равно надо обрабатьвать каждое раскрытие ветки и выбирать данные по необходимости
Это было бы рациональнее с точки зрения скорости и трафика. В какие-то ветки пользователь может вообще никогда не зайти, так зачем читать все подряд?
Дочитывать только при нажатии плюса и отсутствия прочитанных к тому времени данных в этой подветке.


 
sniknik ©   (2006-04-10 12:08) [10]

> Я эти данные сразу и выбираю.
выбираеш на клиента где индекс который на сервере уже по барабану...

не знаю как в IBQuery, а например в ADODataSet можно построить локальный индекс, самый простой способ(заодно и упорядочится) методу Sort имя поля задать. вот после этого уже Locate будет индекс использовать.


 
atruhin ©   (2006-04-10 15:33) [11]


> У меня есть компонент, который отображает данные в виде
> дерева. Я эти данные сразу и выбираю.

А ты думаешь зачем люди старались писали дерево, которое запрашивает данные по мере необходимости? Чтобы ты их все запрашивал на клента , апотом сортировал?


 
Виталий Панасенко   (2006-04-11 10:29) [12]

Сделай FetchAll. Думаю, после этого Locate будет работать быстрее,
т.к. ВСе 40000 записей будут на клиенте
> , а поле индексированно

Индексировано оно для сервера, чтобы клиент при выборке select * from table where id=:id_value получал данные как можно бьстрее(сервер по индексу их быстрее найдет, чем перебором)


 
DancerMan ©   (2006-04-11 12:22) [13]

Всем спасибо!
Выбираю на клиента записи по мере необходимости.
Естественно, увеличились скорость загрузки приложения и скорость перехода на нужную запись.
Вопрос закрыт.



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

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

Наверх




Память: 0.49 MB
Время: 0.044 c
15-1147068298
Некто
2006-05-08 10:04
2006.06.04
CASE-средство визуального проектирования баз данных


4-1142155729
Volf_555
2006-03-12 12:28
2006.06.04
Как закрыть окно Microsoft Internet Explorer?


2-1148119967
tytci2007
2006-05-20 14:12
2006.06.04
Как упаковать в 6 байт дату и время


2-1147855038
aleshap
2006-05-17 12:37
2006.06.04
Метод


15-1147029232
SergProger
2006-05-07 23:13
2006.06.04
Настройка подключения