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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 12.09.2011, 09:36
Аватар для Shoni
Shoni Shoni вне форума
Прохожий
 
Регистрация: 02.09.2011
Адрес: Кострома
Сообщения: 45
Версия Delphi: 7
Репутация: 165
По умолчанию SQL-запрос с параметрами

Доброго времени суток!

Ребят, подскажите, пожалуйста, как запрос переделать, имеется примерно следующее:

Код:
Select * from table1 where (((pole1)=:pole))

в таком случае, скажем, если параметр pole=Иван, то найдет только те записи, значение в указанном поле которого='Иван' или 'иван', а надо, чтобы выводилось 'Иванов', 'Иван Петров' и т.п.

Знаю, что можно делать типа такого:
Код:
Select * from table1 where (pole1 like 'Иван%' )

Но нужно именно с параметром, чтоб для других имен/фамилий тоже подходило... Подскажите, пожалуйста, как
__________________
Memento Mori(арти)
Ответить с цитированием
  #2  
Старый 12.09.2011, 09:48
Аватар для NumLock
NumLock NumLock вне форума
Let Me Show You
 
Регистрация: 30.04.2010
Адрес: Северодвинск
Сообщения: 5,426
Версия Delphi: 7, XE5
Репутация: 59586
По умолчанию

Код:
begin
  Query1.DatabaseName:='DBDEMOS';
  Query1.SQL.Text:='select * from country.db where capital like :param1';
  Query1.Prepare;
  Query1.ParamByName('param1').AsString:='M%';
  Query1.Open;
end;
__________________
Пишу программы за еду.
__________________
Ответить с цитированием
  #3  
Старый 12.09.2011, 09:52
Аватар для Shoni
Shoni Shoni вне форума
Прохожий
 
Регистрация: 02.09.2011
Адрес: Кострома
Сообщения: 45
Версия Delphi: 7
Репутация: 165
По умолчанию

Код:
Query1.ParamByName('param1').AsString:='M%';

а разве в этом случае выведется не все, что начинается с M?
__________________
Memento Mori(арти)
Ответить с цитированием
  #4  
Старый 12.09.2011, 09:57
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

Ну и добавляйте просто к параметру %:
Код:
AdoQuery1.Parameters.ParamValues['Pole1'] := Edit1.Text + '%';
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #5  
Старый 12.09.2011, 09:57
Аватар для NumLock
NumLock NumLock вне форума
Let Me Show You
 
Регистрация: 30.04.2010
Адрес: Северодвинск
Сообщения: 5,426
Версия Delphi: 7, XE5
Репутация: 59586
По умолчанию

ну напиши вместо "М%" "Иван%" и получишь
Цитата:
'Иванов', 'Иван Петров'
__________________
Пишу программы за еду.
__________________
Ответить с цитированием
  #6  
Старый 12.09.2011, 10:17
Аватар для Shoni
Shoni Shoni вне форума
Прохожий
 
Регистрация: 02.09.2011
Адрес: Кострома
Сообщения: 45
Версия Delphi: 7
Репутация: 165
По умолчанию

2 Страдалецъ:

Гениальное - просто ... ^^^ спасибо огромное, даже код сильно менять не пришлось!
__________________
Memento Mori(арти)
Ответить с цитированием
  #7  
Старый 12.09.2011, 12:13
chainik chainik вне форума
Начинающий
 
Регистрация: 30.06.2008
Сообщения: 140
Репутация: 8882
По умолчанию

Select * from table1 where (((pole1)=:рole))

проблему можно решить еще так
Код:
SQL.Text:='Select * from table1 where (pole1 STARTING WITH '':рole'')'
STARTING WITH выведет все что начинается на эту подстроку
и это равносильно :рole+'%'
но не все версии SQL этот оператор поддерживают.
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter