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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 11.12.2009, 21:22
Yurk@@@ Yurk@@@ вне форума
Прохожий
 
Регистрация: 16.11.2009
Сообщения: 21
Репутация: 10
По умолчанию Проблема при выполнении запроса

вот код:

Код:
ADOQuery2.SQL.Text:='select fam from aaa where Code="'+edit3.Text+'"';
ADOQuery2.ExecSQL;
ADOQuery2.SQL.Text:='select * from aaa';
ADOQuery2.Active:=False;
ADOQuery2.Active:=True;

lmikle: пользуемся тегами!!!

Пишу в едит3 порядковый номер,вывожу в DBGrid.
Возникает ошибка:"несоответствие типов данных в выражении...."
Помогите плиз
Ответить с цитированием
  #2  
Старый 11.12.2009, 21:28
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,003
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Ну да. У тебя какой тип поля Code?
Даже если строка, то там все-равно надо одинарными кавычками обрамляьб значение.
Ответить с цитированием
  #3  
Старый 11.12.2009, 22:04
Kapitoshka438 Kapitoshka438 вне форума
Начинающий
 
Регистрация: 09.11.2009
Сообщения: 145
Репутация: 238
По умолчанию

Вообще в таких случаях следует пользоваться параметрами:
Код:
ADOQuery2.SQL.Text:='select fam from aaa where Code=:Code';
ADOQuery2.Parameters.ParamValues['Code'] := Edit3.Text;
ADOQuery2.ExecSQL;
ADOQuery2.SQL.Text:='select * from aaa';
ADOQuery2.Active:=False;
ADOQuery2.Active:=True;
Строку запроса складывают по частям в иных случаях, например, когда в качестве параметра выступает таблица.

Только непонятно, что у вас тут просходит. Вы делаете выборку из таблицы 'aaa' в никуда, потом сразу меняете запрос и выбираете все данные из таблицы. Зачем тогда первый запрос?
Ответить с цитированием
  #4  
Старый 12.12.2009, 02:24
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

Код:
ADOQuery2.SQL.Text:='select fam from aaa where Code=:Code';
ADOQuery2.Parameters.ParamValues['Code'] := Edit3.Text;
ADOQuery2.ExecSQL;
Я может чего не понимаю, но нафига это все наворочено?
Если предполагается получить fam из ADOQuery2 то надо ADOQuery2.Open или ADOQuery2.Active := True;
Так ведь не похоже на то, т.к. дальше-то все это героически убивается.
Код:
ADOQuery2.SQL.Text:='select * from aaa';
ADOQuery2.Active:=False;
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #5  
Старый 12.12.2009, 02:24
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

Код:
ADOQuery2.SQL.Text:='select fam from aaa where Code=:Code';
ADOQuery2.Parameters.ParamValues['Code'] := Edit3.Text;
ADOQuery2.ExecSQL;
Я может чего не понимаю, но нафига это все наворочено?
Если предполагается получить fam из ADOQuery2 то надо ADOQuery2.Open или ADOQuery2.Active := True;
Так ведь не похоже на то, т.к. дальше-то все это героически убивается.
Код:
ADOQuery2.SQL.Text:='select * from aaa';
ADOQuery2.Active:=False;
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #6  
Старый 12.12.2009, 11:30
Yurk@@@ Yurk@@@ вне форума
Прохожий
 
Регистрация: 16.11.2009
Сообщения: 21
Репутация: 10
По умолчанию

Прошу прощения, что ввёл в заблуждение этим запросом. Работает вариант, предложенный lmikle и Kapitoshka438. Тогда в чём разница между SELECT и ADOQuery2.Parameters? Суть вопроса : надо организовать поиск по порядковому номеру, который вводит юзер.
Страдалецъ - спасибо за замечание, всё переделал
Ответить с цитированием
  #7  
Старый 13.12.2009, 11:07
Babuca Babuca вне форума
Прохожий
 
Регистрация: 09.08.2009
Сообщения: 27
Репутация: 10
По умолчанию

Цитата:
Сообщение от Yurk@@@
Тогда в чём разница между SELECT и ADOQuery2.Parameters?
они вместе составляют запрос с параметрами.

А запрос вот такой.
Код:
with aaa do
begin
  Close;
  SQL.Clear
  SQL.Add('Select fam From aaa Where Code=:Code');
  Parameters.ParamByName('Code').Value := Edit3.Text;
  Open;
end;
Ответить с цитированием
  #8  
Старый 13.12.2009, 23:38
Kapitoshka438 Kapitoshka438 вне форума
Начинающий
 
Регистрация: 09.11.2009
Сообщения: 145
Репутация: 238
По умолчанию

Строку запроса можно сформировать, как сумму строк. Но при этом строка запроса должна в итоге быть синтаксически правильной. Например, правильный запрос должен выглядеть так:
Код:
ADOQuery2.SQL.Text:='select fam from aaa where Code='''+edit3.Text+''';
// Здесь все кавычки одинарные (их по три штуки)
Но можно использовать запросы с параметры. Запрос посылается на сервер, например, в виде:
Код:
ADOQuery2.SQL.Text:='select fam from aaa where Code=:Code
В этом случае сервер при выполнении запроса ждет значение параметра Code, и здесь не нужно беспокоиться за кавычки.
А первый способ нужно использовать, если вы меняете таблицы, из которых происходит выборка, т.к. их нельзя посылать в запрос через параметры.
Код:
ADOQuery2.SQL.Text:='select fam from ''' + edit3.Text + ''' where ...';
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter