Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2002.11.11;
Скачать: [xml.tar.bz2];

Вниз

Контекстный поиск в таблице   Найти похожие ветки 

 
maras   (2002-10-22 10:05) [0]

Ситуация такая.
Задается строка поиска _stroka.
Нужно отобрать из таблицы (Pdox или dBase) строки в заданных полях F1,F2...
Fn которой содержится строка _stroka (но не точное соответствие, а
вхождение). Поля F1,F2... Fn как текстовые так и числовые.
Выбор в каком поле из F1,F2... Fn искать, осуществляется с помощью СheckBox
(cbF1,cbF2..cbFn).
Сделала - путем перебора всех записей таблицы и проверкой
pos(_stroka,F1)>0 (при cbF1.Checked) и т.д.
Все работает. Но при количестве записей >500 уже просто действует на нервы.
Может кто-то подскажет как сделать быстро и элегантно( с ProgressBar -ом и
прочими прибамбасами)
Спасибо заранее, Марина
Можно ответить MSS68@mail.ru


 
Anatoly Podgoretsky   (2002-10-22 10:14) [1]

Select * from tbl where (fld1 like "%val%") or (fld1 like "%val%")
Строку формировать динамически в зависимость от условий поиска


 
sniknik   (2002-10-22 10:23) [2]

может будет побыстрее если использовать запрос вроде
SELECT * FROM [Table] WHERE (F1+F2+...Fn LIKE "%Строка%")
и после по ключу (ключевое поле) из запроса перемещатся по таблице?

но быстрым такой поиск вряд ли сделаеш, без использования индексов в любом случае перебор таблици ...


 
Anatoly Podgoretsky   (2002-10-22 10:32) [3]

Индексы для LIKE не помогут


 
sniknik   (2002-10-22 10:36) [4]

В том то и дело (может я непонятно выразился) что в любом случае будет перебор таблици.


 
Anatoly Podgoretsky   (2002-10-22 10:43) [5]

Но достаточно эффективный по сравнению с жругими методами



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

Форум: "Базы";
Текущий архив: 2002.11.11;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.45 MB
Время: 0.007 c
14-34171
Карлсон
2002-10-12 14:38
2002.11.11
где план достать и хватит ли одной тонны пластида.


1-33968
linage
2002-11-01 13:46
2002.11.11
Менеджер расположения компонентов


1-34098
vvolkov
2002-10-31 13:51
2002.11.11
Сохранение TControl


14-34226
RV
2002-10-19 10:59
2002.11.11
Меня сегодня убьют....


3-33879
Romanos
2002-10-21 10:26
2002.11.11
Вставка записи





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский