powered by simpleCommunicator - 2.0.61     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / Delphi [игнор отключен] [закрыт для гостей] / Delphi и MySQL через ADO
16 сообщений из 16, страница 1 из 1
Delphi и MySQL через ADO
    #39527630
Angara
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Добрый день! Создала приложение Дельфи с использование БД MySQL 5.2. Соединялась через My SQL ODBC 5.1 драйвер посредством компонента ADOConnection. Теперь нужно показать разработанное приложение преподавателю. Знаю, что просто скопировав папку с проектом на компьютер преподавателя, база не откроется. Какие файлы нужно таскать с собой, либо что настроить на компе препода, чтобы база работала и у него. SQL сервер и ODBC драйвер у препода тот же, что и у меня.
...
Рейтинг: 0 / 0
Delphi и MySQL через ADO
    #39527827
Фотография JayDi
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Надо чтобы и база была общая (чтобы к ней был доступ как из дома, так от преподавателя). Иначе придется делать бекап базы, а потом через что-нибудь восстанавливать.

ADOConnection содержит строку для подключения (connection string). Надо ее сохранить к себе в код, а вместо адреса базы, логина и пароля поставить символ %s... А потом заполнять в коде типа:
Код: pascal
1.
connectionString := Format('строка', [server, login, password, database]);


в свою очередь эти переменные с сервером и доступом хранить в текстовом файле рядом с программой и при старте их считывать... Если лень это делать, то можно тупо эти текстовые поля в самой программе сделать и кнопку подключения.
...
Рейтинг: 0 / 0
Delphi и MySQL через ADO
    #39527902
Фотография Gator
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
...
Рейтинг: 0 / 0
Delphi и MySQL через ADO
    #39528266
Angara
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
JaDi, Если скопировать папку с созданной БД в папку MySQL\MySQL Server 5.2\data на компе препода и настроить параметры ODBC драйвера через Панель управления -> Администрирование, а в самом коде при подключении к БД прописать код, который вы предлагаете, то БД успешно запустится?
...
Рейтинг: 0 / 0
Delphi и MySQL через ADO
    #39528551
Фотография JayDi
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
AngaraJaDi, Если скопировать папку с созданной БД в папку MySQL\MySQL Server 5.2\data на компе препода и настроить параметры ODBC драйвера через Панель управления -> Администрирование, а в самом коде при подключении к БД прописать код, который вы предлагаете, то БД успешно запустится?
Для ConnectionString ничего настраивать в панели администрирования не надо -- можно напрямую писать доступ к базе. А вот то, что сам драйвер должен быть установлен -- это тонкий момент. Если у препода он стоит -- хорошо. А если нет? Конечно, можно и в источники данных добавить базу -- тогда верно -- настроек не потребуется. Но мне легче прямо в программы сделать нужные поля для подключения и вставлять их в Connection String.

Кроме того замена файлов в папке дата -- это довольно авантюрное решение. Вдруг версия базы не та, вдруг данные препода затрутся, вдруг еще что-то случится. Самый надежный способ -- это дамп базы данных в виде SQL-файла. Его можно будет импортировать любым удобным способом (выполнить скрипт по созданию и заполнению базы) -- хоть через сторонний софт, хоть через командную строку.
...
Рейтинг: 0 / 0
Delphi и MySQL через ADO
    #39528624
Angara
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
JaDi, я скачала, установила zeusdb. Настроила свойства компонентов ZConnection1 и ZQuery. В папку с проектом поместила файл libmySQL.dll (на всякий случай, вдруг нужен). Не подскажете, что еще нужно сделать? или этого достаточно чтобы открыть БД на компьютере преподавателя?
...
Рейтинг: 0 / 0
Delphi и MySQL через ADO
    #39528625
Фотография JayDi
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Angara,

этого достаточно... теперь главное, чтобы в самом приложении не было активных подключение -- connecte - false, а датасеты с active - false...

И тогда при запуска можно откуда-то грузить данные о подключении для вставки в зеус-соединение.
...
Рейтинг: 0 / 0
Delphi и MySQL через ADO
    #39528728
Angara
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
JaDi, а как быть с БД? Должен ли быть на компьютере преподавателя установлен ODBC - драйвер? Нужно ли дамп-файл базы данных скидывать ему на комп, если да, то в какую папку? нужно ли дамп-файл держать в папке проекта?
Извините за такие глупые вопросы, просто я новичок в mysql
...
Рейтинг: 0 / 0
Delphi и MySQL через ADO
    #39528732
Angara
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
JaDi, с вопросом про ODBC это я перегнула. Нам ведь теперь он не нужен, т.к. мы используем совсем иной способ подключения.
(Если я в чем-то ошибаюсь, прошу поправить).

Расскажу по порядку как я настраивала компоненты zeos.
Код: pascal
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
//Для компонента ZConnection1
ZConnection1.HostName := localhost (возможно нужно указать ip - адрес моего компьютера. Нет?);
ZConnection1.Database := servis_cent;
ZConnection1.User := root;
ZConnection1.Password := 00112299;
ZConnection1.Port := 3306;
ZConnection1.Protocol := mysql;
ZConnection1.Connected:=false;

//Для компонента ZQuery1:
ZQuery1.Connection:=ZConnection1;
ZQuery1.SQL:='SELECT * from zayavki';
ZQuery1.Active:=false;


В DataSource1 в свойстве DataSet указала ZQuery1.
Связь с DBGrid тоже установлена.

Теперь, насколько я поняла, надо чтобы при запуске программы, база данных считывала данные из ZConnection1. Для этого, видимо, надо прописать нечто подобное:

Код: pascal
1.
2.
3.
4.
5.
6.
7.
8.
ZConnection1.HostName := localhost (возможно нужно указать ip - адрес моего компьютера. Нет?);
ZConnection1.Database := servis_cent;
ZConnection1.User := root;
ZConnection1.Password := 00112299;
ZConnection1.Port := 3306;
ZConnection1.Protocol := mysql;
ZConnection1.Connected:=true;
ZQuery1.Active:=true;



А вот куда это прописать, я тоже не знаю (на какой форме, или может это в файле проекта прописать, если да, то между какими строками). Объясните пожалуйста))))
...
Рейтинг: 0 / 0
Delphi и MySQL через ADO
    #39528735
Angara
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
JaDi, разве можно подключиться к моей БД с другого компьютера (используя мой ip-адрес), если компьютеры не связаны по локальной сети? Возможно, мне стоит установить денвер или есть другой путь, полегче?
...
Рейтинг: 0 / 0
Delphi и MySQL через ADO
    #39528754
Angara
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
JaDi, и если нужно в качестве имени хоста указывать ip-адрес, то какой именно (внешний или основной)?
...
Рейтинг: 0 / 0
Delphi и MySQL через ADO
    #39528762
Фотография JayDi
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Angara,

localhost -- это адрес текущего компьютера, на котором запущено приложение. Если база преподавателя находится на нем же, то это имя можно так и ставить.

Angaraи если нужно в качестве имени хоста указывать ip-адрес, то какой именно (внешний или основной)?
Внешний. Тот, что показывается на яндексе при поиске "мой айпи", например. Там же в онлайн сервисах надо проверить, чтобы был открыт порт 3306.

Angaraразве можно подключиться к моей БД с другого компьютера (используя мой ip-адрес), если компьютеры не связаны по локальной сети? Возможно, мне стоит установить денвер или есть другой путь, полегче?
Если компьютеры не связаны по локальной сети, то подключиться нельзя. В крайнем случае можно использовать связь через интернет -- подключаться по ип-адресу. Но для этого должны быть некоторые условия (например, открытый порт 3306 на домашнем роутере/компьютере, разрешенный доступ к базе под учеткой root с внешних компьютеров -- эта галочка ставится при установке mysql, либо при создании нового пользователя). Кстати, самый простой способ подключиться через интернет к домашнему компьютеру для настроек или проверки/скачивания чего либо -- использовать TeamViewer .

Angaraкак быть с БД? Должен ли быть на компьютере преподавателя установлен ODBC - драйвер? Нужно ли дамп-файл базы данных скидывать ему на комп, если да, то в какую папку? нужно ли дамп-файл держать в папке проекта?
Извините за такие глупые вопросы, просто я новичок в mysql
Odbc уже не нужен. А вот с дампом базы -- хороший вопрос. Лучше узнать у преподавателя, какой софт или инструменты для работы с базой у него доступны. Возможно, у него уже что-то есть там (сторонний софт для работы типа dbforge for mysql -- бесплатный кстати на русском языке; либо phpmyadmin). И уже от него отталкиваться. В крайнем случае можно будет принести с собой утилиту mysqldump, которая есть в основной поставке и скриптом восстанавливать через нее. Если совсем туго -- то могу скинуть на почту свою утилиту, где визуально можно подключиться к базе, создать пользователя или поставить дамп базы.
...
Рейтинг: 0 / 0
Delphi и MySQL через ADO
    #39528840
asutp2
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Можно использовать MyDAC от DevArt (платная библиотека), тогда не нужно ничего таскать вместе с приложением. Достаточно указать компоненту ip/порт и логин/пароль сервера с базой и вуаля, никаких дополнительных dll/exe/etc не потребуется.
Останется только решить вопрос с местоположением самой базы
...
Рейтинг: 0 / 0
Delphi и MySQL через ADO
    #39528946
Angara
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
asutp2, мне не нужна общая БД. Есть способ просто перенести БД на другой компьютер и подключиться к ней, используя предложенный компонент?
...
Рейтинг: 0 / 0
Delphi и MySQL через ADO
    #39528954
Angara
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
asutp2, не отвечайте. Получилось перенести БД на другой комп при помощи создания dump файла. А далее моя БД через ZEOS прекрасно к ней подключилась. Буду тестировать дальше. Надеюсь ошибок при работе с БД не возникнет
...
Рейтинг: 0 / 0
Delphi и MySQL через ADO
    #39528960
Angara
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
JaDi, Спасибо вам большое!!!! Вы мне подкинули идею про dump-файл и библиотеку ZEOS. Я позже здесь распишу как мне удалось реализовать перенос приложения написанного в Delphi 7 + MySQL на другой компьютер, чтобы остальным не пришлось убивать на это две недели в поиске информации и чтении книг.
...
Рейтинг: 0 / 0
16 сообщений из 16, страница 1 из 1
Форумы / Delphi [игнор отключен] [закрыт для гостей] / Delphi и MySQL через ADO
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]