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

Вниз

MIDAS   Найти похожие ветки 

 
изм ©   (2003-08-19 13:53) [0]

Прошу сильно не пинать только учусь

проблема у меня следующая:

Есть сервер приложения на нем DataBase1, Session1 (AutoSesionName = true) и пара таблиц с провайдерами,
есть метод

procedure TSimple.Connect(const UserName, Password: WideString; out DidLogin: HResult);
begin
Database1.Params.Clear;
Database1.Params.Add("PASSWORD="+Password);
Database1.Params.Add("USER NAME="+UserName);
FPassword := Password;
FUserName := UserName;
try
DidLogin := 0;
Database1.Open;
except
DidLogin := 1;
raise;
end;
end;

у клиента
несколько TClientDataSet, FISimple :ISimple;
и процедура

procedure TForm2.btConnectClick(Sender: TObject);
var
R: HRESULT;
begin
FISimple := CoSimple.Create;
FISimple.Connect("SYSDBA", "1", R);
if R = 0 then
begin
cdsCustomer.Open;
cdsVendors.Open;
end;
end;

теперь собственно вопрос почему для одного клиента создается две сессии (на открытие базы и на открытие таблиц) и как это лечить?


 
Digitman ©   (2003-08-19 14:50) [1]

сам же пишешь

> несколько TClientDataSet


при такой схеме сколько объектов TClientDataSet -
столько и сессий получаешь на стороне сервера


 
изм ©   (2003-08-19 15:03) [2]

а разве не по Connection
кроме того я ставил одну таблицу а сессий было все равно две


 
Vlad ©   (2003-08-19 15:09) [3]

Попробуй коннект к базе не с клиента, а с сервера приложений.
Т.е. в начале каждого метода вызывай свой Connect
Возможно в этом причина.


 
Dred2k ©   (2003-08-19 16:32) [4]

Если юзаешь BDE, то есть такая глобальная переменная Session.
Она всегда создается и открывается, уничтожать нельзя (в хелпе все о ней есть).


 
изм ©   (2003-08-19 16:55) [5]

2 Vlad
на сервере приложени есть метод коннект который вызывается на клиенте, а как еще !?

2 Dred2k в BDE, насколько я понимаю глобальная переменная Session покажывает какая сессия в данный момент отображается в визуальных компонентах


 
Dred2k ©   (2003-08-19 17:00) [6]

> изм © (19.08.03 16:55)

В хелп залезь и все увидишь.


 
изм ©   (2003-08-19 17:04) [7]

вопрос решился оказалось что в методе btConnectClick нет необходимости создавать сервер, после того как открывается связь
Connection.Open сервер запускается автоматически, и устанавливает соедитение с базой при cdsCustomer.Open т.е еще раз
вылечил

DBCon.Open;
(DBCon.aPPSERVER AS ISimple).cONNECT();
далее по тексту



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

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

Наверх




Память: 0.48 MB
Время: 0.022 c
14-33769
вовка
2003-08-21 19:56
2003.09.11
3D рисование


14-33752
Skier
2003-08-22 14:53
2003.09.11
Опять по


3-33527
LIK22
2003-08-19 12:49
2003.09.11
Помогите с SubString.


1-33608
dataMaster
2003-09-01 13:32
2003.09.11
Как запретить изменение ширины колонок в ListView


1-33580
pavel_guzhanov
2003-08-28 15:30
2003.09.11
Использование PrintDialog