Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2005.09.04;
Скачать: CL | DM;

Вниз

Копия TDatabase   Найти похожие ветки 

 
Алексей Петухов   (2005-07-24 09:05) [0]

Здравствуйте, уважаеме мастера.

Подскажите как можно создать рабочую копию компонента TDataBase, если имеется Указатель ввиде Integer на исходный компонент?
Так чтобы копия была полностью идентичной оригиналу (параметры, алиас логин, пароль и т.д.)

Есть необходимость вызвать из одного приложения другое, которое будет работать с той-же бд. Но первое может быть завершено без взаимовлияний с вызванным.


 
Leonid Troyanovsky ©   (2005-07-24 09:18) [1]


> Алексей Петухов   (24.07.05 09:05)  
> Здравствуйте, уважаеме мастера.
>
> Подскажите как можно создать рабочую копию компонента TDataBase,
> если имеется Указатель ввиде Integer на исходный компонент?
> Так чтобы копия была полностью идентичной оригиналу (параметры,
>
>
> Есть необходимость вызвать из одного приложения другое,
> которое будет работать с той-же бд. Но первое может быть
> завершено без взаимовлияний с вызванным.


Нужно передать алиас логин, пароль и т.д. другому
приложению путем к.л. IPC: pipes, WM_COPYDATA, memory mapped file etc. или хоть в комстроке.

--
Regards, LVT.


 
msguns ©   (2005-07-24 12:58) [2]

В этом случае, имхо, наверное грамотнее говорить не о "копии" TDataBase, а об указателе на активную и открытую БД. А если так, то для правильного ответа надо бы знать тип используемой БД ("локалка", SQL-сервер етц)


 
DrPass ©   (2005-07-24 17:07) [3]


> а об указателе на активную и открытую БД.

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


 
just_me   (2005-07-24 18:55) [4]

Создать во втором (дочернем) приложении экземпляр TDataBase и его сврйству Hahdle присвоить Hahdle от TDataBase первого приложения. Таким образом, например, решается проблема передача открытого в приложении соединения в DLL


 
Ученик   (2005-07-24 21:20) [5]

>just_me   (24.07.05 18:55) [4]
А DLL и другое приложение понятия одного уровня (в плане Handle) ?


 
Юрий Зотов ©   (2005-07-25 03:57) [6]

Создать TMemoryStream, сделать в него WriteComponent. Второму приложению передать ID процесса, адрес и размер потока. Второе  делает ReadProcessMemory и ReadComponent, затем посылает первому сообщение. Получив его, первое убивает поток.


 
Алексей Петухов   (2005-07-25 08:38) [7]


> msguns ©  

Тип БД - MSSQL server. Локальный или Обычный


 
msguns ©   (2005-07-25 09:50) [8]

>Алексей Петухов   (25.07.05 08:38) [7]
>Тип БД - MSSQL server. Локальный или Обычный

Вопрос №2

"Второе" приложение :
а) только читает
б) только пишет
с) пишет и читает

Насколько важно запросы основного и "второго" приложения выполнять в контексте одной транзакции ?

И вообще, если можно, поподробнее о логике приложения в целом.


 
Алексей Петухов   (2005-07-25 12:35) [9]

Второе приложение пишет и читает.

Транзакции не критичны.

Второе приложение - это динамическая справочная система (в том числе контекстно-зависимая) к первому пиложению.


 
msguns ©   (2005-07-25 12:50) [10]

>Алексей Петухов   (25.07.05 12:35) [9]
>Транзакции не критичны.
>Второе приложение - это динамическая справочная система (в том числе контекстно-зависимая) к первому пиложению.

Если второе приложение суть интерфейс со справочником, т.е. для просмотра и выбора из справочника в основное приложение, да еще с возможностью редактирования этого справочника, то транзакции критичны.

Если нельзя интерфейс со справочником оформить как форму, то нужно "согласовать" оба этих приложения. Либо через общий интерфейс либо через вынос всей логики БД в отдельное приложение (Application Server).

Попутно вопрос: чем вызвано использование BDE (TDataBase) при работе с MSSQL ? Чем не устроил ADO+Jet ?

ЗЫ. Вопрос, имхо, больше в тему "Базы".



Страницы: 1 вся ветка

Текущий архив: 2005.09.04;
Скачать: CL | DM;

Наверх




Память: 0.49 MB
Время: 0.041 c
1-1123723393
Просто
2005-08-11 05:23
2005.09.04
Можно ли чёрно-белую bmp-картинку загрузить как курсор?


8-1114117100
RyDmi
2005-04-22 00:58
2005.09.04
Стереовыход


1-1124108568
KA_
2005-08-15 16:22
2005.09.04
Прошу оценить статью


3-1121936680
Fynjy1984
2005-07-21 13:04
2005.09.04
сумму по модулю DBGridEh


3-1122274772
Term
2005-07-25 10:59
2005.09.04
Как сделать STOP и START MSSQL программно