Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ]
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 17.08.2010, 20:31
Аватар для Electronic_Arts
Electronic_Arts Electronic_Arts вне форума
Местный
 
Регистрация: 13.07.2006
Адрес: на земле
Сообщения: 562
Версия Delphi: Delphi 11
Репутация: 18
Восклицание Поиск по буквам

Как осуществить поиск по половине текста
сделал переменную чтоб упростить себе работу

select * from base where Name like :name

теперь при поиске надо выводить полное имя чтоб поиск дал результатов
а можно сделать поиск по половине имени?
__________________
Нет ничего не возможного. Вопрос только во времени...
Ответить с цитированием
  #2  
Старый 17.08.2010, 22:14
Аватар для Bars1992
Bars1992 Bars1992 вне форума
Активный
 
Регистрация: 24.04.2010
Адрес: Украина, Кременчуг
Сообщения: 249
Репутация: 22
По умолчанию

Если я тебя правельно понял то почитай про функцию POS
__________________
Не твори зла, и жизнь повернется к тебе передом
Ответить с цитированием
  #3  
Старый 18.08.2010, 00:44
Asinkrit Asinkrit вне форума
Местный
 
Регистрация: 29.10.2009
Сообщения: 446
Репутация: 271
По умолчанию

Код:
select * from base where name like '%'+name+'%'
Ответить с цитированием
  #4  
Старый 27.08.2010, 18:38
Аватар для Electronic_Arts
Electronic_Arts Electronic_Arts вне форума
Местный
 
Регистрация: 13.07.2006
Адрес: на земле
Сообщения: 562
Версия Delphi: Delphi 11
Репутация: 18
Восклицание

Не помогло - выдает ошибку уже при вводе текста
__________________
Нет ничего не возможного. Вопрос только во времени...
Ответить с цитированием
  #5  
Старый 27.08.2010, 18:58
Asinkrit Asinkrit вне форума
Местный
 
Регистрация: 29.10.2009
Сообщения: 446
Репутация: 271
По умолчанию

Что за ошибка?
Ответить с цитированием
  #6  
Старый 27.08.2010, 23:39
Аватар для Electronic_Arts
Electronic_Arts Electronic_Arts вне форума
Местный
 
Регистрация: 13.07.2006
Адрес: на земле
Сообщения: 562
Версия Delphi: Delphi 11
Репутация: 18
Восклицание

ОШИБКА!
Booktable2: Parameter 'Name' not found.
__________________
Нет ничего не возможного. Вопрос только во времени...
Ответить с цитированием
  #7  
Старый 28.08.2010, 00:48
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,096
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Полный код покажи.
Ответить с цитированием
  #8  
Старый 28.08.2010, 01:29
Аватар для Electronic_Arts
Electronic_Arts Electronic_Arts вне форума
Местный
 
Регистрация: 13.07.2006
Адрес: на земле
Сообщения: 562
Версия Delphi: Delphi 11
Репутация: 18
Восклицание

Код:
Select from BASE where name like :''%''+name+''%''

Поиск

Код:
BookTable2.parameters.ParamByName('name').value:=edit1.text;
__________________
Нет ничего не возможного. Вопрос только во времени...

Последний раз редактировалось Electronic_Arts, 28.08.2010 в 01:32.
Ответить с цитированием
  #9  
Старый 28.08.2010, 01:45
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,096
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Ну попробуй так:

Код:
Select from BASE where name like '%' + :name + '%'

Хотя боюсь, что придется в динамике пересобирать весь запрос.
Ответить с цитированием
  #10  
Старый 28.08.2010, 02:03
Аватар для Electronic_Arts
Electronic_Arts Electronic_Arts вне форума
Местный
 
Регистрация: 13.07.2006
Адрес: на земле
Сообщения: 562
Версия Delphi: Delphi 11
Репутация: 18
Восклицание

Код:
booktable2.SQL.Text:='select * from Base where Name LIKE ''%'' + :Name + ''%'''
Ошибка остается !
__________________
Нет ничего не возможного. Вопрос только во времени...

Последний раз редактировалось Electronic_Arts, 28.08.2010 в 02:08.
Ответить с цитированием
  #11  
Старый 28.08.2010, 02:58
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,096
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

тогда пробуй так:
Код:
booktable2.SQL.Text:='select * from Base where Name LIKE ''%'+edit1.text+ '%''';
booktable2.Open;

Без параметра!!!
Ответить с цитированием
  #12  
Старый 28.08.2010, 14:12
Аватар для Electronic_Arts
Electronic_Arts Electronic_Arts вне форума
Местный
 
Регистрация: 13.07.2006
Адрес: на земле
Сообщения: 562
Версия Delphi: Delphi 11
Репутация: 18
По умолчанию

Параметр Name не имеет значения по умолчанию.

Не помогло.!
__________________
Нет ничего не возможного. Вопрос только во времени...
Ответить с цитированием
  #13  
Старый 28.08.2010, 18:44
Asinkrit Asinkrit вне форума
Местный
 
Регистрация: 29.10.2009
Сообщения: 446
Репутация: 271
По умолчанию

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

Вот держи, не проверял, но должно работать:
Код:
  with booktable2 do
    begin
    DisableControls;
    if Active then Close;
    SQL.Clear;
    Params.Clear;
    SQL.Text:='select * from Base where name like '+QuotedStr('%'+name+'%');
    Open;
    Last;
    First;
    EnableControls;
    end;

Последний раз редактировалось Asinkrit, 28.08.2010 в 18:51.
Ответить с цитированием
  #14  
Старый 10.09.2010, 17:30
Аватар для Electronic_Arts
Electronic_Arts Electronic_Arts вне форума
Местный
 
Регистрация: 13.07.2006
Адрес: на земле
Сообщения: 562
Версия Delphi: Delphi 11
Репутация: 18
Восклицание

Громадное спасибо только что проверил - все работает - СПАСИБО СПАСИБО СПАСИБО
__________________
Нет ничего не возможного. Вопрос только во времени...
Ответить с цитированием
  #15  
Старый 10.09.2010, 17:54
Аватар для Electronic_Arts
Electronic_Arts Electronic_Arts вне форума
Местный
 
Регистрация: 13.07.2006
Адрес: на земле
Сообщения: 562
Версия Delphi: Delphi 11
Репутация: 18
Восклицание

версия которую предложил lmikle тоже работает - извините пожалуйста...проблема была во мне я просто взял и скопировал кон даже не посмотрев....
__________________
Нет ничего не возможного. Вопрос только во времени...
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 13:13.


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2025