С++ ADO SQL DBGrid помогите решить проблему запроса

компьютеры sql С++ ADO

Есть форма, есть дата модуль. На форме висит кнопка, и едит и дь грид. В едит вводим данные для поиска, при нажатии кнопки должны обновляться данные в дбгрид.

void __fastcall TFpoiskpipl::BBpoiskpipClick(TObject *Sender)
{
//DBmod->Qbook->Active=false;
DBmod->Qbook->Close();
DBmod->Qbook->SQL->Clear();
DBmod->Qbook->SQL->Add("SELECT fam");
DBmod->Qbook->SQL->Add("FROM book");
DBmod->Qbook->SQL->Add("WHERE fam = " +ed->Text);
DBmod->Qbook->Open();
DBG->Refresh();
}

Но пишет ошибку Параметр *который введен в едит* не имеет значения по умлочанию.

Что делать???
Ответы:
тут спросите
может Параметр *который введен в едит* надо заключать в кавычки?
->Add("WHERE fam = ' " +ed->Text+" ' ");
Твистер прав - не хватает кавычек.
Если введешь в ed текст, например ZZZ, и посмотришь  SQL запрос перед тем, как выполнится DBmod->Qbook->Open();, то там будет:
SELECT fam FROM book WHERE fam = ZZZ
SQL в этому случае, думает, что ZZZ, это переменная-параметр, а она нигде не определена. он пытается всунуть default-значение. его тоже нет...
правильный запрос должен быть такой:
SELECT fam FROM book WHERE fam = 'ZZZ'


15 лет назад

RPI.su - самая большая русскоязычная база вопросов и ответов. Наш проект был реализован как продолжение популярного сервиса otvety.google.ru, который был закрыт и удален 30 апреля 2015 года. Мы решили воскресить полезный сервис Ответы Гугл, чтобы любой человек смог публично узнать ответ на свой вопрос у интернет сообщества.

Все вопросы, добавленные на сайт ответов Google, мы скопировали и сохранили здесь. Имена старых пользователей также отображены в том виде, в котором они существовали ранее. Только нужно заново пройти регистрацию, чтобы иметь возможность задавать вопросы, или отвечать другим.

Чтобы связаться с нами по любому вопросу О САЙТЕ (реклама, сотрудничество, отзыв о сервисе), пишите на почту [email protected]. Только все общие вопросы размещайте на сайте, на них ответ по почте не предоставляется.