![]() |
|
|
Регистрация | << Правила форума >> | FAQ | Пользователи | Календарь | Поиск | Сообщения за сегодня | Все разделы прочитаны |
![]() |
|
Опции темы | Поиск в этой теме | Опции просмотра |
#1
|
|||
|
|||
![]() Есть база данных на sql с номерами телефонов и пример поиска из edit нужного телефона в ней
Код:
ADOQueryPoisk.Sql.Add(select NomerTel.id from NomerTel where Номер like :PoiskNomer); ADOQueryPoisk.Parameters.ParamByName('PoiskNomer').Value := StrToFloat(Edit1.Text); Номер телефона ищется только при полном совпадении, а как сделать, чтобы искалась только какая-то часть номера? Последний раз редактировалось lmikle, 27.08.2015 в 17:54. |
#2
|
|||
|
|||
![]() LIKE %text% спасет отца русской демократии:
Код:
ADOQueryPoisk.Sql.Add(select NomerTel.id from NomerTel where Номер like :PoiskNomer); ADOQueryPoisk.Parameters.ParamByName('PoiskNomer').Value := '%' + StrToFloat(Edit1.Text) + '%'; |
#3
|
|||
|
|||
![]() Уже пробовал. Выдает ошибку несоответствие типов, так как у переменной PoiskNomer тип float (числовой, а не строковый), как и у столбца Номер. Проблема в том, чтобы сделать проверку вхождения одного числа в другое. Возможно ли это для чисел в Delphi 2010?
|
#4
|
|||
|
|||
![]() Ну, можно и конвертнуть в строку (прямо в запросе). База Аксес?
Вообще, нафига тел. № сохранять как число??? Да еще и типа float. Переделай в строку, будет проще. Еще варианты: 1. Можно попробовать сгенерировать такой набор чисел и условий из введенного числа, которые будут работать аналогично LIKE. Проблемма, что кол-во условий (комплексеых, которые будут записаны через OR) будет Length(Phone)-Length(PhonePart)+1, замучаешься отлаживать. 2. Можно просто выборку проверять на клиенте, получить весь датасет и его уже динамически фильтровать. Т.к. тут фильтрация идет кодом, то можно писать любые проверки, в т.ч. и через конвертацию в строку и простой Pos. |