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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 10.12.2009, 21:56
Аватар для Лунтик-Некрофил
Лунтик-Некрофил Лунтик-Некрофил вне форума
Начинающий
 
Регистрация: 28.09.2009
Сообщения: 165
Репутация: 12
По умолчанию Помогите разобраться...

Проблема проста, и я уверен что Вы сможете мне помочь.
Есть БД, нужно сделать поиск с помощью SQL.
Код:
Select * from www.db where fio='+edit1.text+';
На примере попытка сделать отбор по полю ФИО удовлетворяющих значений Edit1. Однако после активации Query DBGrid остается пустым.
В чем дело?
Заранее благодарен, с ув. Лунтик-Некрофил.
Ответить с цитированием
  #2  
Старый 10.12.2009, 21:58
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,029
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

для начала:
1. Где кавычки вокруг значения поля.
2. Это сравнение с учетеом регистра. Ты уверен, что это правильно.
3. Не наравится мне имя таблицы, но это уже детали.
Ответить с цитированием
  #3  
Старый 10.12.2009, 22:11
Аватар для Лунтик-Некрофил
Лунтик-Некрофил Лунтик-Некрофил вне форума
Начинающий
 
Регистрация: 28.09.2009
Сообщения: 165
Репутация: 12
По умолчанию

1. С кавычками перебрал великое множество вариантов, результат тот же.
2. С регистром уверен.
3. Это уже детали.
Я понимаю, что краткость чья-то там сестра, но всё же - нельзя ли немного поинформативнее? Желательно с правильно оформленным примером, если Вам не сложно.
Ответить с цитированием
  #4  
Старый 10.12.2009, 23:21
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,029
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Код:
Query1.SQL.Text := 'SELECT * FROM www.db WHERE fio = '''+edit1.Text+'''';
Query1.Open;

Должно быть так.
А вообще тут у тебя условие на точное совпадение, т.е. даже любой пробел в поле или в едите даст уже неравенство.
Ответить с цитированием
  #5  
Старый 10.12.2009, 23:41
Аватар для Лунтик-Некрофил
Лунтик-Некрофил Лунтик-Некрофил вне форума
Начинающий
 
Регистрация: 28.09.2009
Сообщения: 165
Репутация: 12
По умолчанию

Большое спасибо, работает). А как сделать на частичное совпадение? Например у метода Locate был option(или что-то подобное), где можно было записать учет регистра, частичное совпадение и т.п. Через SQL такое реально?
Заранее спасибо.
Ответить с цитированием
  #6  
Старый 11.12.2009, 00:15
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

У вас Парадокс как я понял, там диалект SQL может несколько отличаться от стандарта. Так попробуйте:
Код:
Query1.SQL.Text := 'SELECT * FROM www.db WHERE fio like ''%'+edit1.Text+'%''';
Возможно не процент а звездочка.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #7  
Старый 11.12.2009, 02:04
Аватар для Лунтик-Некрофил
Лунтик-Некрофил Лунтик-Некрофил вне форума
Начинающий
 
Регистрация: 28.09.2009
Сообщения: 165
Репутация: 12
По умолчанию

К сожалению не помогло... Но не в этом теперь дело)
Возникла новая проблемка - надо поставить радиогруппу. В ней записанны поля таблицы. Т.е. словами юзера "Выбираем в радио нужное поле для поиска->Пишел в строке ввода нужную нам запись-> Оп, нашлось".
Задачка не очень тяжелая, но не могу разобраться с этими ковычками, делфи ругается, либо не находит записей вообще.
Код:
var s:string;
begin
case radiogroup1.ItemIndex of
0:s:='Fio';
1:s:='Znak';
2:s:='Data';
end;
Query1.Close;
Query1.SQL.Clear;
Query1.SQL.Text := 'SELECT * FROM www.db WHERE ''s''='''+edit1.Text+'''';
query1.Open;

Как мне устроить переменную s поудобней чтобы и программа работала, и делфи по пустякам меня матом не крыла?
Заранее спасибо)
Ответить с цитированием
  #8  
Старый 11.12.2009, 08:18
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

С кавычками вложенными лучше так бороться:
Код:
Query1.SQL.Text := Format('SELECT * FROM www.db WHERE %s=%s',[s,QuotedStr(Edit1.Text)]);
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #9  
Старый 11.12.2009, 11:10
Аватар для Лунтик-Некрофил
Лунтик-Некрофил Лунтик-Некрофил вне форума
Начинающий
 
Регистрация: 28.09.2009
Сообщения: 165
Репутация: 12
По умолчанию

Страдалецъ, огромное спасибо, помогли нереально)
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter