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

Вниз

ADO поиск   Найти похожие ветки 

 
777 ©   (2002-04-11 18:37) [0]

Имеется DB MSSQL (>140000 записей),коннект через ADO, надо организовать быстрый поиск.
К сожалению на данный момент в SQL я ориентируюсь
на уровне SELECT *, пытался использовать ADOTable.Lookup, Locate
- всё работает, но ОЧЧень медленно.


 
Aleksandr ©   (2002-04-11 20:28) [1]

Организовывай через формирование запроса:

with TADOQuery.Create(nil) do try
Connection:=MyConnection;
SQL.Add("SELECT * FROM "+TableName);
SQL.Add("WHERE ID1="+IntToStr(SearchId)+" AND Name1="+SearchName);
SQL.Add("ORDER By ID1");
try
Open;
DoSomething;
Close
except
end
finally
Free
end


 
Aleksandr ©   (2002-04-11 20:33) [2]

ЗЫ: У меня через такое дело таблицы в 600 000 записей в секунду укладываются... Можно также сделать формированием строки Filter у компоненты. Предпоследнюю строку запроса туда. Истчо быстрее будет, потому как фильтр работает с уже пришедшим набором данных, что его неслабо ускоряет. Тот же эффект будет, если набор данных у тебя был уже открыт, и в вышеуказанный код после Connection вставляешь:
DataSet:=MyOpenedQuery;


 
777 ©   (2002-04-11 20:37) [3]


> Aleksandr ©

спасибо!


 
777 ©   (2002-04-12 11:43) [4]

А как всё-таки быть с динамическим поиском,
а-ля FindNearest?


 
Johnmen ©   (2002-04-12 11:55) [5]

SELECT * FROM TBL WHERE FLD LIKE ....
для символьных полей.


 
Delirium ©   (2002-04-12 12:28) [6]

Вообще RecordSet-ы могут быть "проидексированы", как результат такой "локальной индексации" поиск с помощью Locate ускоряется в несколько раз. Для этого необходимо проделать следущее:

ADOQuery1.Close;
ADOQuery1.SQL.Text:="select id_name,c_name from r_names";
ADOQuery1.Open;
// А вот и "индексация" - опимизация RecordSet-а по конкретному полю
ADOQuery1.Recordset.Fields["id_name"].Properties["Optimize"].Value:=True;
ADOQuery1.Locate("id_name","17517",[loPartialKey]);



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

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

Наверх




Память: 0.48 MB
Время: 0.008 c
3-17470
AlexA
2002-04-12 10:30
2002.05.06
IBQuery.Modifiеd


3-17491
Wasp
2002-04-12 11:01
2002.05.06
Jet SQL, UPDATE и SELECT


14-17679
vajo
2002-03-22 13:51
2002.05.06
Безопасность W2000


6-17664
fixxxer
2002-02-20 14:10
2002.05.06
посылка E-mail через TNMSMTP


1-17602
sir_musatov
2002-04-22 16:40
2002.05.06
поменять позицию курсора в поле edit