23.02.2018, 07:41 [+3 UTC]
в нашей команде: 2 560 чел. | участники онлайн: 2 (рекорд: 21)

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

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

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

:: правила

:: новости

:: участники

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

:: форум

:: блоги

:: поиск

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

:: наш журнал

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

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

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

:: поддержка

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

Версия системы:
7.44 (14.02.2018)

Общие новости:
02.01.2018, 09:46

Форум:
11.02.2018, 23:11

Последний вопрос:
22.02.2018, 17:35

Последний ответ:
21.02.2018, 16:44

Последняя рассылка:
22.02.2018, 23:15

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

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

Наша кнопка:

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

Отзывы о нас:
28.10.2009, 17:56 »
Чехлов Д.М.
Спасибо за доп. информацию! [вопрос № 173788, ответ № 255968]
25.12.2011, 16:57 »
Евгений
Уважаемая команда rfpro! Большое спасибо за ваши рассылки. У меня пока не возникало ситуаций, требующих посторонней помощи - мне удается самостоятельно решать возникающие проблемы. Но я сохраняю все приходящие письма. Ваш портал - очень ценный источник информации, "золотая жила". Желаю вам успешной работы.
06.12.2012, 05:55 »
Иванов Анатолий Николаевич
+5 Благодарю за помощь! С уважением, Анатолий. [вопрос № 186888, ответ № 271793]

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

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

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

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

Зенченко Константин Николаевич
Статус: Модератор
Рейтинг: 335
Вадим Исаев ака sir Henry
Статус: Старший модератор
Рейтинг: 52
Евгений/Genia007/
Статус: Профессионал
Рейтинг: 21

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

Консультация онлайн # 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.13738 сек.

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