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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 03.03.2010, 11:38
Аватар для DenProx
DenProx DenProx вне форума
Прохожий
 
Регистрация: 03.03.2010
Адрес: г. Челябинск
Сообщения: 4
Репутация: 10
По умолчанию Фильтрация Loockup поля

Доброго времени суток. У меня такой вопрос, я пытаюсь сделать фильтрацию по полю подстановки (loockup), пишу такой код:

Код:
ADOQuery3.Active:=False;
ADOQuery3.SQL.Clear;
ADOQuery3.SQL.Add('SELECT *');
ADOQuery3.SQL.Add('FROM tblDetail');
if Edit1.Text<>EmptyStr then
ADOQuery3.SQL.Add('WHERE Section_ID IN (SELECT Key FROM tblSection WHERE SectionName LIKE '''+Edit1.Text+'%'+''')');
ADOQuery3.Active:=True;

где tblDetail таблица с ссылками, т.е. содеожит коды полей
tblSection - таблица с соответствующими именами

проблема в следующем, при вводе в Едит текста, таблица становится пустой, и фильтрация соответственно не осуществляется... но если данный запрос проверить в Access'e то все работает... в чем может быть проблема?
__________________
Чаще всего, у большенства людей, поиск Истины заканчивается набором слова в Гугле
Ответить с цитированием
  #2  
Старый 03.03.2010, 12:17
Аватар для TOJluK
TOJluK TOJluK вне форума
Местный
 
Регистрация: 25.02.2009
Адрес: Минск
Сообщения: 551
Версия Delphi: 2007
Репутация: 110
По умолчанию

Да вроде все правильно, попробуй Quotedstr(Edit1.Text+'%').
Не уверен, но если регистр в аксесе учитывается- может в этом проблема. Попробуй Edit1.Text передать как параметр, или для начала вообще оставить просто LIKE %. Посмотри что получится.
Ответить с цитированием
  #3  
Старый 03.03.2010, 12:37
Аватар для DenProx
DenProx DenProx вне форума
Прохожий
 
Регистрация: 03.03.2010
Адрес: г. Челябинск
Сообщения: 4
Репутация: 10
По умолчанию

не выходит, результат все тот же...
пробывал так:
Код:
ADOQuery3.SQL.Add('WHERE Section_ID IN (SELECT Key FROM tblSection WHERE SectionName LIKE ''д%'')');
__________________
Чаще всего, у большенства людей, поиск Истины заканчивается набором слова в Гугле
Ответить с цитированием
  #4  
Старый 03.03.2010, 13:25
Аватар для DenProx
DenProx DenProx вне форума
Прохожий
 
Регистрация: 03.03.2010
Адрес: г. Челябинск
Сообщения: 4
Репутация: 10
По умолчанию

Нашел ошибку, дело было в том что ADOQuery был связан с другим, по этому фильтр не работает... от сюда вопрос, как можно совместить чтобы и связь была, и фильтр работал?
__________________
Чаще всего, у большенства людей, поиск Истины заканчивается набором слова в Гугле
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter