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

Не понимаю почему выдает ошибку при подключении к БД

01.06.2022, 19:41. Показов 6223. Ответов 10

Студворк — интернет-сервис помощи студентам
Я написал вот так, но выдает ошибку, что не может найти ADOTableInvest И DataSourceInvest, Хотя Client нашел вроде в Form 1
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
oid __fastcall TForm2::N3Click(TObject *Sender)
 
void __fastcall TForm2::N3Click(TObject *Sender)
{
const String ConnStr = "Provider=%s;Data Source=%s;Mode=%s";
if (OpenDialog1->Execute())
{
Form1->ADOTableClient->ConnectionString = Format (ConnStr,
ARRAYOFCONST(("Microsoft.Jet.OLEDB.4.0",(String)OpenDialog1->FileName,
"Read")));
DBGrid1->DataSource=Form1->DataSourceClient;
Form1->DataSourceClient->DataSet=Form1->ADOTableClient;
Form1->ADOTableClient->Active=true;
Form1->ADOTableInvest->ConnectionString = Form1->ADOTableInvest->ConnectionString;
DBGrid2->DataSource=Form1->DataSourceInvest;
Form1->DataSourceInvest->DataSet=Form1->ADOTableInvest;
Form1->ADOTableInvest->Active=true;
}
}
Мне нужно сделать подключение к БД через OpenDialog
Миниатюры
Не понимаю почему выдает ошибку при  подключении к БД  
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
01.06.2022, 19:41
Ответы с готовыми решениями:

Не понимаю почему выдаёт ошибку при вводе процедуры в код
Только учусь программированию на самом базовом языке, поэтому никак не могу понять почему мне выдаёт ошибку: "неверное количество...

Выдает ошибку не понимаю почему
Помогите Выдает ошибку не понимаю почему именно в строчке где я хочу закрыть форму по нажатию на кнопку #pragma endregion private:...

Не понимаю почему выдает ошибку
procedure TForm1.Button1Click(Sender: TObject); var f : textfile; i : integer; begin if OpenDialog1.Execute then begin ...

10
Модератор
 Аватар для D1973
9907 / 6444 / 2455
Регистрация: 21.01.2014
Сообщений: 27,353
Записей в блоге: 3
02.06.2022, 21:53
1. Тот факт, что обращаетесь из одной формы к компонентам, расположенным на другой... Нужные модули приинклюдили?
2. Все компоненты для подключения и работы с БД надо размещать в отдельном DataModule, если разрабатываете многооконное приложение (что в 99% случаев совершенно не нужно и не оправданно)
3. Нельзя делать для каждого компонента свое подключение! Для подключения к БД используется компонент ТADOConnection, для него динамически создается строка подключения и осуществляется это самое подключение. Все остальные компоненты подключаются к БД, используя уже установленное соединение.
4. Использование TADOTable в качестве набора данных (собственно, как и ADO в целом) - принципы и методы работы прошлого тысячелетия.
5. Почему режим открытия БД - Read? Вы что, не собираетесь вносить изменения или добавлять данные в базу? Очень странно, прямо скажем...
0
0 / 0 / 0
Регистрация: 31.03.2022
Сообщений: 37
04.06.2022, 16:58  [ТС]
Цитата Сообщение от D1973 Посмотреть сообщение
компоненты для подключения и работы с БД надо размещать в отдельном DataModule, если разрабатываете многооконное
Цитата Сообщение от D1973 Посмотреть сообщение
1. Тот факт, что обращаетесь из одной формы к компонентам, расположенным на другой... Нужные модули приинклюдили?
2. Все компоненты для подключения и работы с БД надо размещать в отдельном DataModule, если разрабатываете многооконное приложение (что в 99% случаев совершенно не нужно и не оправданно)
3. Нельзя делать для каждого компонента свое подключение! Для подключения к БД используется компонент ТADOConnection, для него динамически создается строка подключения и осуществляется это самое подключение. Все остальные компоненты подключаются к БД, используя уже установленное соединение.
4. Использование TADOTable в качестве набора данных (собственно, как и ADO в целом) - принципы и методы работы прошлого тысячелетия.
5. Почему режим открытия БД - Read? Вы что, не собираетесь вносить изменения или добавлять данные в базу? Очень странно, прямо скажем..
Я решил вопрос с этим, там Unit1 не там находился и программа поэтому найти не могла, сейчас вроде все заработало.

Добавлено через 1 минуту
Цитата Сообщение от D1973 Посмотреть сообщение
4. Использование TADOTable в качестве набора данных (собственно, как и ADO в целом) - принципы и методы работы прошлого тысячелетия.
Ну вот такая методичка в ВУЗе, я просто делал на основе примера, что препод скинула.
Теперь мне нужно сделать экспорт в Эксель, поможете с этим, я нашел ваши ответы по этому поводу в 2015 году на форме, но что то сам разобраться не смогу, там вроде тоже с помощью ADOTable делали БД. Экспорт в Excel
0
Модератор
 Аватар для D1973
9907 / 6444 / 2455
Регистрация: 21.01.2014
Сообщений: 27,353
Записей в блоге: 3
04.06.2022, 17:00
Цитата Сообщение от Summer_ Посмотреть сообщение
я просто делал на основе примера
и что, в этом примере тоже для каждого компонента своя строка подключения? Да не поверю!
0
0 / 0 / 0
Регистрация: 31.03.2022
Сообщений: 37
04.06.2022, 17:01  [ТС]
Цитата Сообщение от D1973 Посмотреть сообщение
и что, в этом примере тоже для каждого компонента своя строка подключения? Да не поверю!
Вы имеете ввиду, для каждого свой DataSource?
Или каждому свой ADOTable?
0
Модератор
 Аватар для D1973
9907 / 6444 / 2455
Регистрация: 21.01.2014
Сообщений: 27,353
Записей в блоге: 3
04.06.2022, 17:14
Нет. Я имею в виду, что для каждого ADOTable отдельное свойство ConnectionString - это неправильно!
0
0 / 0 / 0
Регистрация: 31.03.2022
Сообщений: 37
04.06.2022, 20:35  [ТС]
Цитата Сообщение от D1973 Посмотреть сообщение
Нет. Я имею в виду, что для каждого ADOTable отдельное свойство ConnectionString - это неправильно!
А как нужно?

Добавлено через 2 часа 57 минут
Цитата Сообщение от D1973 Посмотреть сообщение
Нет. Я имею в виду, что для каждого ADOTable отдельное свойство ConnectionString - это неправильно!
Вы тут?
0
Модератор
 Аватар для D1973
9907 / 6444 / 2455
Регистрация: 21.01.2014
Сообщений: 27,353
Записей в блоге: 3
05.06.2022, 01:22
Цитата Сообщение от Summer_ Посмотреть сообщение
А как нужно?
Так написал же:
Цитата Сообщение от D1973 Посмотреть сообщение
Нельзя делать для каждого компонента свое подключение! Для подключения к БД используется компонент ТADOConnection, для него динамически создается строка подключения и осуществляется это самое подключение. Все остальные компоненты подключаются к БД, используя уже установленное соединение.
0
0 / 0 / 0
Регистрация: 31.03.2022
Сообщений: 37
05.06.2022, 13:38  [ТС]
Цитата Сообщение от D1973 Посмотреть сообщение
Нельзя делать для каждого компонента свое подключение! Для подключения к БД используется компонент ТADOConnection, для него динамически создается строка подключения и осуществляется это самое подключение. Все остальные компоненты подключаются к БД, используя уже установленное соединение.
Я посмотрел пример от препода, вроде такого не нашел, вот она
Вложения
Тип файла: pdf Пример для КР по базам данных Крамаренко.pdf (1.21 Мб, 5 просмотров)
0
Модератор
 Аватар для D1973
9907 / 6444 / 2455
Регистрация: 21.01.2014
Сообщений: 27,353
Записей в блоге: 3
05.06.2022, 13:45
Про DataModule там сказано, но вот то, что каждый набор данных имеет свое подключение к БД - дичь дичайшая.
0
0 / 0 / 0
Регистрация: 31.03.2022
Сообщений: 37
05.06.2022, 14:05  [ТС]
Цитата Сообщение от D1973 Посмотреть сообщение
Про DataModule там сказано, но вот то, что каждый набор данных имеет свое подключение к БД - дичь дичайшая.
Получается методичка плохого уровня?
Можете помочь мне с экспортом данных, создал отдельную тему
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
05.06.2022, 14:05
Помогаю со студенческими работами здесь

Не понимаю почему выдает ошибку
Вам поручено написать систему распределения доступа к файлам. Она должна не пускать пользователя к тем файлам, прочитать которые у него не...

Выдает ошибку, не понимаю почему!
Эта строка подчеркивает красным: if(strcmp(str,"sin")==0) res=sin(res); #include <iostream> #include <conio.h> #include...

Не понимаю почему выдаёт ошибку
Сделал такой код, очень кривой, потому что только начал изучать язык, не очень понимаю почему выдаёт ошибки. Ошибки с 2ух сторон отметил...

Не понимаю почему выдает эту ошибку
Здравствуйте, вот код программы( игра змейка ). Все вроде правильно, но выдает ошибку : main: недопустимые локальные определения функций....

ошибка! программа выдает ошибку неинициализированнная переменная s, не понимаю почему
доброго времени суток, программа выдает ошибку "использована неинициализированная локальная переменная "s" ". я ее обьявил,...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США. Нашел на реддите интересную статью под названием «Кто-нибудь знает, где получить бесплатный компьютер или. . .
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 - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru