Форум программистов, компьютерный форум, киберфорум
C++ Builder: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.81/42: Рейтинг темы: голосов - 42, средняя оценка - 4.81
1 / 1 / 0
Регистрация: 02.12.2011
Сообщений: 30

Добавление записи в БД Acess через ADOQuery

06.05.2012, 17:40. Показов 8705. Ответов 42
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте! Помогите пожалуйста, хочу добавить данные в базу следующим образом:

C++
1
2
3
4
5
ADOQuery2->Close();
ADOQuery2->SQL->Clear();
ADOQuery2->SQL->Text = "INSERT INTO ghd (End) VALUES(:End)";
ADOQuery2->Parameters->Items[0]->Value=Edit1->Text;
ADOQuery2->ExecSQL();
Но вместо добавления строки вылетает ошибка
Миниатюры
Добавление записи в БД Acess через ADOQuery  
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
06.05.2012, 17:40
Ответы с готовыми решениями:

Добавление записи через ADOQuery
Всем привет, помогите плиз, хочу добавить даныне с едитов в БД, но вылетает ошибка Form1->ADOQuery1->Close(); ...

Добавление записи в таблицу через ADOQuery
Здравствуйте) В моей программе таблица базы данных подключена к компоненту ADOQuery, насколько я понимаю SQL в свойствах обязатльно для...

Добавление записи через ADOQuery
Помогите пожалуйста организовать добавление записи используя sql запрос. Причем имеются три таблицы ОС, Наименование, название Делаю...

42
1569 / 505 / 48
Регистрация: 04.04.2009
Сообщений: 1,891
06.05.2012, 19:38
klepan, а почему бы к имени параметра не обратиться?

C++
1
2
3
4
5
ADOQuery2->Close();
ADOQuery2->SQL->Clear();
ADOQuery2->SQL->Text = "INSERT INTO ghd (End) VALUES(:End)";
ADOQuery1->Parameters->ParamByName("End")->Value=Edit3->Text;
ADOQuery2->ExecSQL();
0
1 / 1 / 0
Регистрация: 02.12.2011
Сообщений: 30
06.05.2012, 19:58  [ТС]
При написании этого кода

C++
1
2
3
4
5
ADOQuery2->Close();
ADOQuery2->SQL->Clear();
ADOQuery2->SQL->Text = "INSERT INTO ghd (End) VALUES(:End)";
ADOQuery2->Parameters->ParamByName("End")->Value=Edit1->Text;
ADOQuery2->ExecSQL();
выскакивает другая ошибка
Миниатюры
Добавление записи в БД Acess через ADOQuery  
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
06.05.2012, 20:03
А ты попробуй придумать другое имя параметру
0
1 / 1 / 0
Регистрация: 02.12.2011
Сообщений: 30
06.05.2012, 20:07  [ТС]
К сожалению та же ерунда, ума не приложу что не так...
0
1 / 1 / 0
Регистрация: 02.12.2011
Сообщений: 30
06.05.2012, 20:12  [ТС]
если пишу

C++
1
ADOQuery2->SQL->Text = "INSERT INTO ghd (End) VALUES('"+Edit1->Text+"')";
пишет
Миниатюры
Добавление записи в БД Acess через ADOQuery  
0
1569 / 505 / 48
Регистрация: 04.04.2009
Сообщений: 1,891
06.05.2012, 20:17
klepan, дык у вас в ADOQuery2 (Poperties - Connection) указано соединение (компонента ADOConnection1, к примеру) ?
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
06.05.2012, 20:20
Добавлено через 1 минуту
Цитата Сообщение от The_Immortal Посмотреть сообщение
klepan, дык у вас в ADOQuery2 (Poperties - Connection) указано соединение (компонента ADOConnection1, к примеру) ?
Да действительно проверьте строку подключения
0
1 / 1 / 0
Регистрация: 02.12.2011
Сообщений: 30
06.05.2012, 20:29  [ТС]
C++
1
2
3
4
ADOQuery2->Close();
ADOQuery2->SQL->Clear();
ADOQuery2->SQL->Text = "INSERT INTO ghd (End) VALUES('"+Edit1->Text+"')";
ADOQuery2->ExecSQL();
Добавлено через 6 минут
Проверил строку подключения
теперь пишет, что ошибка синтаксиса в инструкции INSERT INTO
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
06.05.2012, 20:41
Если проект не большой, то выложи я гляну
0
1 / 1 / 0
Регистрация: 02.12.2011
Сообщений: 30
06.05.2012, 20:49  [ТС]
Только не обращайте внимания на оформление и все остальное, это специально, чтоб понять почему не работает
0
1 / 1 / 0
Регистрация: 02.12.2011
Сообщений: 30
06.05.2012, 21:00  [ТС]
Вот папка с проектом
Вложения
Тип файла: rar Новая папка (2).rar (1.39 Мб, 94 просмотров)
0
1569 / 505 / 48
Регистрация: 04.04.2009
Сообщений: 1,891
06.05.2012, 21:08
А вот так попробуйте:

C++
1
2
3
4
5
ADOQuery2->Close();
ADOQuery2->SQL->Clear();
ADOQuery2->SQL->Text = "INSERT INTO ghd ([End]) VALUES(:End)";
ADOQuery2->Parameters->ParamByName("End")->Value=Edit1->Text;
ADOQuery2->ExecSQL();
Мало ли...
0
1 / 1 / 0
Регистрация: 02.12.2011
Сообщений: 30
06.05.2012, 21:20  [ТС]
Ошибок не выскочило, но данные в таблицу не добавились

Добавлено через 3 минуты
Хотя нет, добавляются! и ошибок не выдает!

Добавлено через 15 секунд
Хотя нет, добавляются! и ошибок не выдает!
0
1569 / 505 / 48
Регистрация: 04.04.2009
Сообщений: 1,891
06.05.2012, 21:20
klepan, если ошибки не выскочило, то инфа должна была добавиться. Откройте саму БД, посмотрите там содержимое таблицы ghd.
1
1 / 1 / 0
Регистрация: 02.12.2011
Сообщений: 30
06.05.2012, 21:30  [ТС]
Спасибо!)

Добавлено через 4 минуты
Вы не подскажите, как теперь обновить данные в DBGrid?

Добавлено через 3 минуты
Все, понял! Спасибо огромное за помощь еще раз!!
0
1569 / 505 / 48
Регистрация: 04.04.2009
Сообщений: 1,891
06.05.2012, 21:44
Как обновляете, если не секрет?
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
06.05.2012, 22:35
Цитата Сообщение от The_Immortal Посмотреть сообщение
Как обновляете, если не секрет?
Повторно запрос сделать на выборку и всё
0
1569 / 505 / 48
Регистрация: 04.04.2009
Сообщений: 1,891
06.05.2012, 22:59
Sasha, это понятно, а как без этого обойтись?
Я погуглил, многие советуют:
C++
1
2
ADOQuery2->Active=false;
ADOQuery2->Active=true;
Ну или Close-Open.

Но у меня после добавления записи на это вылетает: "Текущий поставщик не поддерживает возврат нескольких наборов записей в результате выполнения одной операции"
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
06.05.2012, 23:02
А что в свойстве SQL прописано?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
06.05.2012, 23:02
Помогаю со студенческими работами здесь

Добавление записи через adoquery
Привет я новичек в разработки приложении по запросам в adoquery, можно сказать только начинаю до этого работал в adotable, как пересел на...

Добавление записи в таблицу БД через ADOQuery
Доброго времени суток. Как добавить запись в таблицу БД через ADOQuery, получив нужные значения из эдитов? Для понимания: Ввел в три...

Добавление записи в БД Acess
Здравствуйте, возникла такая проблема: при добавлении записи в базу данных происходит только обновление информации в datagridView , а сама...

Программное удаление записи из БД Acess через Datagridview
Доброго времени суток. Реализовал добавление данных в БД, но не могу понять как эти данные из БД удалить. Должно работать так : ...

ADOQuery добавление записи в дочернюю таблицу
Сделано у меня сортировка таблиц по ключам detail - master и возник вопрос,как осуществить добавление,редактирование записи в дочерней...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Ниже машинный перевод статьи The Thinkpad X220 Tablet is the best budget school laptop period . Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы,. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru