Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Добавление записи с помощью sql, adoquery1.SQL.add(...) 
:(
    Опции темы
SkrudjMagdak
Дата 15.1.2010, 15:02 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 17
Регистрация: 3.12.2009

Репутация: нет
Всего: нет



У меня такая проблема:

Код

adoquery1.Active:=false;
adoquery1.SQL.Clear;
adoquery1.SQL.add('INSERT INTO Клиенты (Паспорт,Фамилия,Имя,Отчество) VALUES ('+Edit1.Text+',"'+Edit2.Text+'","'+Edit3.Text+'","'+Edit4.Text+'");');
adoquery1.Active:=true;


Он добавляет запись но выводит такую ошибку:
Текущий проводник не поддерживает возврат нескольких наборов записей в резуьтате одной операции
Что здесь не так?
PM MAIL   Вверх
morpheyushka
Дата 15.1.2010, 15:29 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Зеленый человек
**


Профиль
Группа: Участник
Сообщений: 563
Регистрация: 26.2.2008
Где: Киев

Репутация: нет
Всего: 8



если нужно поставить кавычку, то делается это так - 
Код

sql := 'INSERT INTO ddbtable...VALUES (' + '''' + Edit1.Text + '''' + ');';



--------------------
user posted image
Спасибо делается вот так!!!
PM MAIL WWW   Вверх
Vas
Дата 15.1.2010, 15:46 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 830
Регистрация: 29.6.2005
Где: Stavropol region

Репутация: 23
Всего: 28



Код

adoquery1.Active:=false;
adoquery1.SQL.Clear;
adoquery1.SQL.add('INSERT INTO Клиенты (Паспорт,Фамилия,Имя,Отчество) VALUES ('''+Edit1.Text+''', '''+Edit2.Text+''', '''+Edit3.Text+''', '''+Edit4.Text+''')');
adoquery1.ExecSQL;

или
Код

adoquery1.Active:=false;
adoquery1.SQL.Clear;
adoquery1.SQL.add('INSERT INTO Клиенты (Паспорт,Фамилия,Имя,Отчество) VALUES ('+QuotedStr(Edit1.Text)+', '+QuotedStr(Edit2.Text)+', '+QuotedStr(Edit3.Text)+', '+QuotedStr(Edit4.Text)+')');
adoquery1.ExecSQL;



Это сообщение отредактировал(а) Vas - 15.1.2010, 15:48


--------------------
И опыт, сын ошибок трудных, И гений, парадоксов друг, И случай, бог изобретатель. ... (А.С. Пушкин)
PM MAIL   Вверх
SkrudjMagdak
Дата 15.1.2010, 15:57 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 17
Регистрация: 3.12.2009

Репутация: нет
Всего: нет



Vas, а можно узнать что команда "adoquery1.ExecSQL;" делает?
PM MAIL   Вверх
Vas
Дата 15.1.2010, 16:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 830
Регистрация: 29.6.2005
Где: Stavropol region

Репутация: 23
Всего: 28



Кратко: выполняет SQL команды, которые не возвращают наборов данных - это INSERT, UPDATE и DELETE.

А подробно по F1 тебе расскажут.


--------------------
И опыт, сын ошибок трудных, И гений, парадоксов друг, И случай, бог изобретатель. ... (А.С. Пушкин)
PM MAIL   Вверх
SkrudjMagdak
Дата 15.1.2010, 16:15 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 17
Регистрация: 3.12.2009

Репутация: нет
Всего: нет



спасибо большое, Vas!!!
PM MAIL   Вверх
LexuSS
Дата 25.1.2010, 16:05 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 39
Регистрация: 12.10.2007

Репутация: нет
Всего: нет



Немного добавлю.

Код

with ADOQuery1 do
  begin
    Active:=false;
    SQL.Clear;
    SQL.add('INSERT INTO Клиенты (Паспорт, Фамилия, Имя, Отчество) VALUES (:Passport, :Family, :Name, :Father);');
    with Parameters do
      begin
        ParamByName('Passport').Value:=Edit1.Text;
        ParamByName('Family').Value:=Edit2.Text;
        ParamByName('Name').Value:=Edit3.Text;
        ParamByName('Father').Value:=Edit4.Text;
      end;
    ExecSQL;
  end;


Так правильнее писать. )))
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi: Базы данных и репортинг"
Vit
Петрович

Запрещено:

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами


Обязательно указание:

1. Базы данных (Paradox, Oracle и т.п.)

2. Способа доступа (ADO, BDE и т.д.)


  • Литературу по Дельфи обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь
  • 90% ответов на свои вопросы можно найти в DRKB (Delphi Russian Knowledge Base) - крупнейшем в рунете сборнике материалов по Дельфи
  • Вопросы по SQL и вопросы по базам данных не связанные с Дельфи задавать здесь

FAQ раздела лежит здесь!


Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Vit, Петрович.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Delphi: Базы данных и репортинг | Следующая тема »


 




[ Время генерации скрипта: 0.0630 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.