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

Вниз

Поиск в базе!   Найти похожие ветки 

 
Youri ©   (2002-11-06 11:56) [0]

Господа! Очень нужна помощь.
Не знаю как осуществить частичный поиск методом Locate. Нужно искать подстроку в некотором поле. Но не с начала, а например с 5 символа. Например:
В строке "Нужна помощь" необходимо найти строку "жна помо".
Как сделать?
Спасибо!


 
Alexandr ©   (2002-11-06 11:58) [1]

while not(eof) do begin
if pos(...)>0 then break;
next;
end;


 
Max Zyuzin ©   (2002-11-06 12:01) [2]

Можно сделать хитро :)
Сделать в отдельном IBQuery поиск какой надо типа
Select * from mytab where mifield like "%жна помо%"
И локейтить по отображаемуому датасету уже зная строку целиком (лучше по ключю)


 
Alexandr ©   (2002-11-06 12:05) [3]

но будет ли быстрее при этом...


 
Max Zyuzin ©   (2002-11-06 12:19) [4]

Будет или не будет зависит много от чего... А вопрос конечно интересный :) пусть автор ветки попробует и скажет


 
Youri ©   (2002-11-06 12:23) [5]

Alexandr!
Использую ваш метод с циклом. Но поиск в таком случае происходит очень медленно!
Есть ли какие-то другие способы?
Max Zyuzin!
Что делать, если используется не IBQuerry, а IBTable?


 
Max Zyuzin ©   (2002-11-06 12:27) [6]

Какая разница? Добавте еще один компонент IBQuery для выполнения запроса. А Locate делайте уже в вашей Table.


 
Alexandr ©   (2002-11-06 12:37) [7]

самое главное, не использовать IBTable.
В нем все тормоза!


 
Wolf226 ©   (2002-11-06 13:43) [8]

IBTable1.locate("fieldname","жна пом",[loPartialKey])


 
Max Zyuzin ©   (2002-11-06 13:44) [9]

>Wolf226 © (06.11.02 13:43)
Это не поможет. Locate ищет троку с начала.


 
Wolf226 ©   (2002-11-06 14:18) [10]

Sorry. Ошибся.
Кстати. На счет вариантов 1 (Alexandr) и 2 (Max Zyuzin)
При малом объеме наверно лучше вариант 1, при большом - 2.
Но надо проэкспериментировать.



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

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

Наверх




Память: 0.48 MB
Время: 0.016 c
1-82848
ton2
2002-11-14 12:52
2002.11.25
Написание компонент и TDataLink


14-83001
Drova
2002-11-06 23:13
2002.11.25
Что такое одноранговая сеть ?


6-82895
TCrash
2002-09-27 13:07
2002.11.25
Socket к одному IP


1-82810
Кот Бегемот
2002-11-13 16:41
2002.11.25
Как розмножить компонент ?


1-82756
spa
2002-11-13 14:41
2002.11.25
Работа с мегабайтным текстовым файлом