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

Вниз

ADOConnection. Не закрывается соединение с базой данных.   Найти похожие ветки 

 
Shura   (2004-05-11 13:08) [0]

Привет !
Суть проблемы: после запуска приложения устанавливаем соединение с БД ADOConnection.Open. Необходимо в процессе работы перезапустить клиента базы с другими параметрами, задаваемыми в строке ADOConnection.ConnectionString, значения берутся из реестра. Но после Close закрывается только ADO - подключение, а клиент базы не закрывается, и на Open открывается старое подключение.
ADOConnection.KeepConnection:=False.
После закрытия приложения связь рвется сразу, поэтому, как мне кажется, дело не в настройках клиента.
Пробовал найти окно и по хэндлу его закрыть, но тогда Open проходит без ошибок, а клиент вообще не запускается.

Спасибо.
--
Shura


 
Polevi ©   (2004-05-11 13:10) [1]

дело в кешировании соединения на уровне провайдера
смотри параметры подключения


 
Johnmen ©   (2004-05-11 13:28) [2]

>Но после Close закрывается только ADO - подключение, а клиент базы не закрывается

Разрывается соединение. А что значит "клиент базы не закрывается" вообще не ясно...

>ADOConnection.KeepConnection:=False.

А это-то зачем ? Чтобы лишний раз соединяться ?...


 
Shura   (2004-05-11 14:57) [3]

to Polevi: какие параметры, во всяком случае из доступных ни одного похожего на кэширование нет. Хотя по-моему это не в провайдере дело. Пробовал опыт: в процессе работы останавливаю программу в точке останова, делаю ADOConnection.Connected:=False и прерываю программу по Ctrl+F2 - клиент не закрывается, чего нет при нормальном завершении работы.

to Johnmen:
>Разрывается соединение. А что значит "клиент базы не >закрывается" вообще не ясно...

Может оно и разрывается, но не до конца:-). А клиент - это виндовое окно, которое висит в панели задач. После закрытия приложения оно закрывается автоматически.
ADOConnection.KeepConnection:=False - просто где-то на форумах видел что-то аналогичное по теме с таким советом. Может и лишний раз придется соединяться, но кэшированное соединение необходимо как-то закрыть, чтобы создать новое с другими параметрами ! Причем эта операция единичная.


 
KSergey ©   (2004-05-11 16:21) [4]

> [3] Shura   (11.05.04 14:57)
> А клиент - это
> виндовое окно, которое висит в панели задач.

В смысле  - это другое приложение запущено?? Или того-же приложени окно? Но как тогда оно может оставаться после Ctrl+F2??


 
Shura   (2004-05-11 17:21) [5]

>В смысле  - это другое приложение запущено??
Именно. Это стороннее ПО, через которое идет доступ к базе.



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

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

Наверх




Память: 0.48 MB
Время: 0.038 c
6-1081932568
TButton
2004-04-14 12:49
2004.05.30
Как назначить обработчик события сокету


3-1083740118
Alex_2004
2004-05-05 10:55
2004.05.30
Алгоритм заполнения TreeView из БД


14-1084368392
a3a3ello
2004-05-12 17:26
2004.05.30
delphi и XP


4-1082444220
Сережа550
2004-04-20 10:57
2004.05.30
EnumChildWindows


1-1084361905
Ilya53
2004-05-12 15:38
2004.05.30
ActiveX DLL и Delphi