Форум программистов, компьютерный форум, киберфорум
C++ Builder: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.83/47: Рейтинг темы: голосов - 47, средняя оценка - 4.83
to
19 / 19 / 2
Регистрация: 28.10.2010
Сообщений: 296

работа с БД с помощью ADO-компонентов

11.08.2011, 13:27. Показов 9704. Ответов 47
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день, уважаемые форумчане. Вот решил полностью разобраться с БД и ADO-компонентами. Но сразу же столкнулся с такой проблемой. Как узнать сколько таблиц находится в БД и какие у них имена. А также как создать новую таблицу программно средствами ADO. Пишу на с++.
Может кто литературой поможет, а то не нашел ничего путного для билдера и ADO.
Заранее благодарен!!!

Добавлено через 35 минут
Народ помогите, очень нужно!
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
11.08.2011, 13:27
Ответы с готовыми решениями:

Проблема с маской dbedit, который расположен на другой форме от ADO компонентов
Есть форма1, где расположены DBEdit(ы), которым программно задается значение Dataset и Datafield в процедуре onCreate формы1. DataSource и...

Чтение таблицы из БД с помощью ADO
Здавствуйте! У меня такая проблема: нужно из БД ACCESS прочитать таблицу с именем Name и записать ее в файл .txt. Сделала такой каркас: ...

Строка подключения к бд Access? С помощью ADO?
Network=; Provider=; Persist Security Info=True; Initial Catalog=; Data Source=; Use Procedure for Prepare=1; Auto...

47
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
11.08.2011, 19:28
Пошарься на форуме я не раз выкладывал исходники
0
to
19 / 19 / 2
Регистрация: 28.10.2010
Сообщений: 296
11.08.2011, 21:45  [ТС]
та искал не могу найти. подскажи пожалуйста, а то что-то вообще не знаю как его делать.
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
11.08.2011, 23:47
https://www.cyberforum.ru/cpp-... 90867.html
0
to
19 / 19 / 2
Регистрация: 28.10.2010
Сообщений: 296
15.08.2011, 17:46  [ТС]
Спасибо, за помощь. Только вот не пойму, для того что бы программно создать таблицу в БД нужно к ней программно подключиться?
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
15.08.2011, 22:14
НУжно подключиться к базе данных, а потом уже создавать таблицу
0
to
19 / 19 / 2
Регистрация: 28.10.2010
Сообщений: 296
15.08.2011, 22:17  [ТС]
спасибо!!
pr="MSDataShape.1"; что значит эта строка???
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
15.08.2011, 22:28
Цитата Сообщение от to Посмотреть сообщение
спасибо!!
pr="MSDataShape.1"; что значит эта строка???
Где ты это прочитал?
0
to
19 / 19 / 2
Регистрация: 28.10.2010
Сообщений: 296
15.08.2011, 22:41  [ТС]
вот в этой теме
https://www.cyberforum.ru/cpp-... 90867.html

Добавлено через 4 минуты
Sasha, подскажи пожалуйста как соедениться с БД. пробовал как в той теме что ты дал, не получаеться. Выкидывает ошибку
First chance exception at $7526B760. Exception class EDatabaseError with message 'Missing Connection or ConnectionString'. Process Project2.exe (27300)
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
15.08.2011, 22:48
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
void __fastcall TMainForm::FormCreate(TObject *Sender)
{
 String filename = "Компьютерная база.mdb";
  if(!FileExists(ExtractFilePath(Application->ExeName)+filename))
{
   AnsiString ds = "В корневом каталоге отсутствует файл с именем \n\n\t" +filename;
 
     if (Application->MessageBox(ds.c_str(),"Предупреждение",MB_OK +MB_TOPMOST+ MB_ICONWARNING)==IDOK)
  {
     Application->Terminate();
  }
 
}
  
else
 {
   String WayToBase=ExtractFilePath(Application->ExeName)+filename;
  ADOConnection1->ConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source="+WayToBase+";Persist Security Info=True";
   ADOConnection1->Connected = true;
  ADOQuery1->ConnectionString = ADOConnection1->ConnectionString;
  DBGrid1->Options = TDBGridOptions(DBGrid1->Options) >> dgIndicator >> dgTitles >> dgColLines >> dgRowLines >> dgColumnResize >>dgEditing;
  DataSource1->DataSet = ADOQuery1;
  DBGrid1->DataSource = DataSource1;
  DBNavigator1->DataSource = DataSource1;
  ADOQuery1->Active = false;
1
to
19 / 19 / 2
Регистрация: 28.10.2010
Сообщений: 296
16.08.2011, 18:36  [ТС]
спасибо буду пробовать!

Добавлено через 1 минуту
спасибо, буду пробовать

Добавлено через 19 часов 39 минут
А новую БД мне создавать sql-запросом??
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
16.08.2011, 21:04
Цитата Сообщение от to Посмотреть сообщение
спасибо буду пробовать!

Добавлено через 1 минуту
спасибо, буду пробовать

Добавлено через 19 часов 39 минут
А новую БД мне создавать sql-запросом??
Можешь просто в аксессе стандартными средствами
0
to
19 / 19 / 2
Регистрация: 28.10.2010
Сообщений: 296
16.08.2011, 21:17  [ТС]
не мне нужно программно
0
to
19 / 19 / 2
Регистрация: 28.10.2010
Сообщений: 296
19.08.2011, 19:07  [ТС]
Делаю соединения так как ты сказал, но пишет " не выполнена проверка подлинности!". я что-то не так делаю?
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
19.08.2011, 22:17
Цитата Сообщение от to Посмотреть сообщение
Делаю соединения так как ты сказал, но пишет " не выполнена проверка подлинности!". я что-то не так делаю?
Выложи код я посмотрю
0
to
19 / 19 / 2
Регистрация: 28.10.2010
Сообщений: 296
19.08.2011, 22:21  [ТС]
ошибку нашел! но не знаю как исправить. Получается я беру имя файла
C++
1
OpenDialog1->FileName;
и присваиваю его стринговской переменной и потом эту переменную добавляю в ConnectionString
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
19.08.2011, 22:52
Цитата Сообщение от to Посмотреть сообщение
ошибку нашел! но не знаю как исправить. Получается я беру имя файла
C++
1
OpenDialog1->FileName;
и присваиваю его стринговской переменной и потом эту переменную добавляю в ConnectionString
C++
1
2
3
4
5
 if (OpenDialog1->Execute())
{
 String WayToBase = OpenDialog1->FileName;
 ADOQuery1->ConnectionString ="Provider=Microsoft.Jet.OLEDB.4.0;Data Source="+WayToBase+";Persist Security Info=True";
}
0
to
19 / 19 / 2
Регистрация: 28.10.2010
Сообщений: 296
19.08.2011, 22:57  [ТС]
Еще вопрос, Можно сделать так, что бы компонент на расположенный на первом модуле был виден и на втором???

Добавлено через 1 минуту
так и делал все равно ругается
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
19.08.2011, 23:03
Цитата Сообщение от to Посмотреть сообщение
Еще вопрос, Можно сделать так, что бы компонент на расположенный на первом модуле был виден и на втором???
Можно обращайся через родителя



Цитата Сообщение от to Посмотреть сообщение
так и делал все равно ругается
Выложи код ты что-то делаешь не правильно или выложи свой проект если делаешь в 6 билдере
0
to
19 / 19 / 2
Регистрация: 28.10.2010
Сообщений: 296
19.08.2011, 23:12  [ТС]
я так понимаю вот в чем прикол!
метод
C++
1
OpenDialog1->FileName
дает вот такой результат "E:\bd.mdb" . В этом и вся соль, потому что когда ввожу путь "E:\\bd.mdb" все прекрасно работает.

Добавлено через 8 минут
Цитата Сообщение от Sasha Посмотреть сообщение
Можно обращайся через родителя
А можно простенький пример такого обращения? Если не трудно.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
19.08.2011, 23:12
Помогаю со студенческими работами здесь

запрос на удаление таблицы с помощью ADO
В чем ошибка? Хочу удалить таблицу из БД Access. Привожу код: form1.ADOCon.ConnectionString:='Provider=Microsoft.Jet.OLEDB.4.0;' + ...

Добавить данные с помощью DataCombo (ADO)
Нужно с помощью DataCombo не только выбирать из списка готовых значений, но и добавлять новые. Для этого нужно просто набрать новые данные...

Установка пароля на БД Access и её с помощью ADO
Подскажите плис, установил пароль на БД, не могу установить конект ADO контрола с этой базой данных. Выдает ошибку. Свойство Password е...

Проблема подключения к MySQL из VB6 с помощью ADO
цель: программа на ВБ подключиться в ИНете к базе данных для управления записями, таблицами и т.д В тренировочных целях установлен...

Как с помощью ADO получить объект Recordset?
Есть база в Access 2000, есть поле Мемо в ней, мне надо из Бейсика с помощью ADO получить объект Recordset с помощью строки? 'SELECT * FROM...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Киев стоит - украинская песня
zorxor 28.01.2026
wfWdiRqdTxc О Господи, Вечный, Ты . . . Я помоги, Бесконечный. . . Я прошу Ты. . . Я погибаю, спаси. . . Я прошу Тебя Вечный. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru