23.10.2018, 11:41 [+3 UTC]
в нашей команде: 3 033 чел. | участники онлайн: 5 (рекорд: 21)

:: РЕГИСТРАЦИЯ

:: задать вопрос

:: все разделы

:: правила

:: новости

:: участники

:: доска почёта

:: форум

:: блоги

:: поиск

:: статистика

:: наш журнал

:: наши встречи

:: наша галерея

:: отзывы о нас

:: поддержка

:: руководство

Версия системы:
7.51 (29.09.2018)

Общие новости:
24.09.2018, 16:49

Форум:
19.10.2018, 12:24

Последний вопрос:
23.10.2018, 10:46

Последний ответ:
23.10.2018, 09:36

Последняя рассылка:
23.10.2018, 03:15

Писем в очереди:
0

Мы в соцсетях:

Наша кнопка:

RFpro.ru - здесь вам помогут!

Отзывы о нас:
18.04.2010, 12:18 »
shader01
Спасибо, буду на месте решать какой из куллеров выбрать. [вопрос № 177858, ответ № 260841]
30.01.2012, 09:14 »
Евгений/Genia007/
Спасибо, это уже делалось ранее. [вопрос № 185307, ответ № 269760]

РАЗДЕЛ • Pascal / Delphi / Lazarus

Создание программ на языках Pascal, Delphi и Lazarus.

[администратор рассылки: Зенченко Константин Николаевич (Модератор)]

Лучшие эксперты в этом разделе

Зенченко Константин Николаевич
Статус: Модератор
Рейтинг: 623
Асмик Гаряка
Статус: Советник
Рейтинг: 19
Орловский Дмитрий
Статус: Мастер-Эксперт
Рейтинг: 0

Перейти к консультации №:
 

Консультация онлайн # 66089
Раздел: • Pascal / Delphi / Lazarus
Автор вопроса: LanK
Отправлена: 08.12.2006, 12:22
Поступило ответов: 1

Здравствуйте, уважаемые Эксперты!

Долго искал ответ на свой вопрос, но что-то неправильно его "вписываю" в поисковики - не смог найти ответа, может Вы знаете?

Вопрос: Есть база MSSQL (версию точно не знаю кажется 2000) использую TADOConnection (Delphi5). В случае если сети нет приложение "подвисает" на 15 секунд пытаясь соединиться smile не смотря на выставленные таймауты по 1с. Есть мысль, чтобы этого "зависания" избежать как то сначала проверить - а работает ли компьютер с базой? А еще лучше - работает ли там база?

P.S.
Мои размышления - можно сделать через пинг (подключить WinSock, проект чуть раздуется результат будет через 2 сек). Но работает ли база??? И файрволом может быть закрыт пинг :(. Но ведь MSSQL почти наверняка "сидит" на каком то порту и должен отвечать приложениям что он работает?

Состояние: Консультация закрыта

Ответ # 130682 от Вадим Исаев ака sir Henry (Старший модератор)

Здравствуйте, LanK!
Попробуйте такую функцию проверки соединения. В свое время я ее раскопал на сайте http://delphiworld.narod.ru/
uses
ComObj;

function OpenConnection(ConnectionString: String): Boolean;
var
ADODBConnection: OleVariant;
begin
ADODBConnection := CreateOleObject('ADODB.Connection');
ADODBConnection.CursorLocation := 3;
ADODBConnection.ConnectionString := ConnectionString;
ADODBConnection.ConnectionTimeout := 3; {Три секунды на соединение}
Result := True;
try
ADODBConnection.Open;
except
Result := False;
end;
If Result Then
ADODBConnection.Close;
end;
Здесь:
- ConnectionString - это сформированная Вами строка подключения к БД.
Если функция возвращает True - подключение прошло успешно, если False, то подключится не удалось.
Хочу заметить, что если в процессе работы Вам не нужна визуализация данных, например нужно передать в БД команду на модификацию данных в какой-то таблице, то такой способ подключения к БД работает быстрее, чем использование VCL.


Консультировал: Вадим Исаев ака sir Henry (Старший модератор)
Дата отправки: 08.12.2006, 19:55

Рейтинг ответа:

0

[подробно]

Сообщение
модераторам

Отправлять сообщения
модераторам могут
только участники портала.
ВОЙТИ НА ПОРТАЛ »
регистрация »

Мини-форум консультации № 66089

Посетитель

ID: 5994

# 1

= общий = | 11.12.2006, 13:55 | цитировать цитировать  | профиль профиль  |  отправить письмо в личную почту пейджер

sir henry: Увы, 3с превращается в 15-20 секунд, в случае если сеть отключена. Простой пример - создаем "голый" проект, помещаем в него Вашу функцию - отключаем сеть .... 15с - :(. Проверить это можно даже без сервера MSSQL smile сами драйвера ADO так тормозят, поэтому необходим какой то алгоритм узнать - работает или нет НЕ через ADO. Либо пользовать какой другой драйвер, но какой? Чтобы у любого пользователя он был? ADO есть у всех...

 

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

Яндекс Rambler's Top100

главная страница | поддержка | задать вопрос

Время генерирования страницы: 0.14014 сек.

© 2001-2018, Портал RFPRO.RU, Россия
Калашников О.А.  |  Гладенюк А.Г.
Версия системы: 7.51 от 29.09.2018