Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ]
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 12.10.2010, 14:29
true true вне форума
Новичок
 
Регистрация: 03.10.2010
Сообщения: 64
Репутация: 10
По умолчанию Вопрос по БД Access + Делфи

Можно ли подключить другую бузу данных через OpenDialog?
компоненты используемые в базе: AdoConnection, Datasource, Adotable

Вот чтот типа такого:
if Opendialog1.Execute then
AdoConnction1.DataSet...(OpenDialog1.Filename)

Это полюбому не правильный код ну я думаю поймете)) Спасибо отвечающим)
Ответить с цитированием
  #2  
Старый 12.10.2010, 14:35
Аватар для friz
friz friz вне форума
Местный
 
Регистрация: 04.04.2008
Адрес: Минск
Сообщения: 596
Версия Delphi: 2007 & JAVA EE
Репутация: 10670
По умолчанию

можно, просто поменяй нужный кусок в connection string

Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\Documents and Settings\Admin\Рабочий стол\База данных1.mdb;Persist Security Info=False

надо заменять выделенный путь!

это при условии что нету логина и пароля
__________________
Последний раз редактировалось Admin, Сегодня в 10:32.

Последний раз редактировалось friz, 12.10.2010 в 14:38.
Ответить с цитированием
  #3  
Старый 12.10.2010, 18:13
true true вне форума
Новичок
 
Регистрация: 03.10.2010
Сообщения: 64
Репутация: 10
По умолчанию

Цитата:
Сообщение от friz
можно, просто поменяй нужный кусок в connection string

Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\Documents and Settings\Admin\Рабочий стол\База данных1.mdb;Persist Security Info=False

надо заменять выделенный путь!

это при условии что нету логина и пароля

Т.е нужно путь как переменную задать?

н.р s:FileName;

Provider=Microsoft.Jet.OLEDB.4.0;Data Source=+s+;Persist Security Info=False

Так?

Я хочу чтобы можно было открывать другую бд, через пункт открыть

Последний раз редактировалось true, 12.10.2010 в 18:21.
Ответить с цитированием
  #4  
Старый 12.10.2010, 18:29
Аватар для friz
friz friz вне форума
Местный
 
Регистрация: 04.04.2008
Адрес: Минск
Сообщения: 596
Версия Delphi: 2007 & JAVA EE
Репутация: 10670
По умолчанию

да что-то типо того
__________________
Последний раз редактировалось Admin, Сегодня в 10:32.
Ответить с цитированием
  #5  
Старый 12.10.2010, 18:46
true true вне форума
Новичок
 
Регистрация: 03.10.2010
Сообщения: 64
Репутация: 10
По умолчанию

Спасибо большое

А можешь показать что нужно дописать или подправить?

Цитата:
procedure TForm1.N34Click(Sender: TObject);
var
s:string;
begin
if OpenDialog1.Execute then
begin
s:=OpenDialog1.FileName;
DataModule2.ADOTable1.ConnectionString(Provider=Mi crosoft.Jet.OLEDB.4.0;Data Source=+s+;Persist Security Info=False);
end;
end;

Последний раз редактировалось true, 12.10.2010 в 18:53.
Ответить с цитированием
  #6  
Старый 13.10.2010, 00:53
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,723
Репутация: 52347
По умолчанию

Ну во первых, подключать правильнее не каждую таблицу/запрос, а всю базу сразу. Для этого там есть компонент TAdoConnection. А уже TAdoQuery/TAdoTable связывать с установленным подключением.
Во вторых, строка подключения это СТРОКА подключения, и как любые строки в Дельфи они обрамляются в кавычки.
Код:
DataModule2.ADOTable1.ConnectionString := 'Provider=Microsoft.Jet.OLEDB.4.0;Data Source='+s+';Persist Security Info=False';
Создавать дополнительную пременную s только для этих целей нет необходимости, вполне хватит прямого обращения
Код:
DataModule2.ADOTable1.ConnectionString := 'Provider=Microsoft.Jet.OLEDB.4.0;Data Source='+OpenDialog1.FileName+';Persist Security Info=False';
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #7  
Старый 13.10.2010, 10:42
true true вне форума
Новичок
 
Регистрация: 03.10.2010
Сообщения: 64
Репутация: 10
По умолчанию

Спасибо такой код работает адоконекшен у меня есть, но вот в дбгрид все равно не выводит
пробывал датусорс менять все равно..
Код:
DBGrid1.DataSource:=DataModule2.DataSource1;
Ответить с цитированием
  #8  
Старый 13.10.2010, 11:28
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,723
Репутация: 52347
По умолчанию

Что-бы все работало правильно должна быть такая связка:
Connection -> Query -> DataSource -> DBGrid
или
Connection -> Table -> DataSource -> DBGrid
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 07:13.


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2025