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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 14.06.2010, 19:35
SinoSin SinoSin вне форума
Прохожий
 
Регистрация: 14.06.2010
Сообщения: 7
Репутация: 10
По умолчанию Параметры Query

Помогите с такой проблемой:
В SQL запросе использую параметры, но в ответ получаю пустой запрос.
Запрос рабочий - т.е. если в строке SQL вместо параметра поставить искомые данные, то все чудесно работает.
Вот пример запроса:
SELECT sell_id, client_id, blk
FROM sell
WHERE (((sell.blk) like :pr));

Пример обращения к параметру:
dm.Query1.ParamByName('pr').Asstring:=Chr(39)+Edit 8.Text+'%'+Chr(39);
Помогите, пожелуйста, очень нужно :)

Последний раз редактировалось SinoSin, 14.06.2010 в 19:39.
Ответить с цитированием
  #2  
Старый 14.06.2010, 20:11
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,024
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Попробуй убрать оба Chr(39).
Ответить с цитированием
  #3  
Старый 14.06.2010, 20:29
SinoSin SinoSin вне форума
Прохожий
 
Регистрация: 14.06.2010
Сообщения: 7
Репутация: 10
По умолчанию

Что с Chr(39), что без Chr(39), что с '''' вместо него - результат ноль...
Ответить с цитированием
  #4  
Старый 14.06.2010, 20:35
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,024
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Вообще, с LIKE такой фокус редко проходит.
Попробуй просто генерить запрос.
И еще, у тебя может быть LIKE стравниывается с учетом регистра. На это тоже надо заложиться.
Ответить с цитированием
  #5  
Старый 14.06.2010, 20:44
SinoSin SinoSin вне форума
Прохожий
 
Регистрация: 14.06.2010
Сообщения: 7
Репутация: 10
По умолчанию

Пробовал и не LIKE, а простое сравнивание: (((sell.blk)=:pr));
все то же - цифры да, символы нет.
Про регистр думал, и давно исключил - с регистром все в порядке :)
А насчет генерить - уж очень большой запрос в итоге выйти должен (полей 20 используется), поэтому генить ну уж очень не хочется(но видимо придется)....

Последний раз редактировалось SinoSin, 14.06.2010 в 21:07.
Ответить с цитированием
  #6  
Старый 14.06.2010, 20:52
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

А вы какой БД подключаетесь? У вас точно % используется для Like ?
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #7  
Старый 14.06.2010, 21:06
SinoSin SinoSin вне форума
Прохожий
 
Регистрация: 14.06.2010
Сообщения: 7
Репутация: 10
По умолчанию

Подключаюсь к Access'у. Если писать sql вручную, то % работает, * нет.
В чем весь интерес и заключается: я даже значение параметра проверяю в процессе - полное сходство строк, но ввожу значение в параметр - не работает, ввожу вручную без параметра - работает.
Ответить с цитированием
  #8  
Старый 14.06.2010, 21:41
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,024
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Э-э-э...
Как я понял, используется компонент TADOQuery.
Там, когда создашь параметр (укажешь в запросе) надо зайти в параметры в Object Inspector и подрастроить их...
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter