Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 04.12.2009, 12:34
PavluxaF PavluxaF вне форума
Прохожий
 
Регистрация: 04.05.2009
Сообщения: 9
Репутация: 10
По умолчанию Подключение к MSSQL

Доброго времени суток!
Необходимо получить и вывести список доступных в локальной сети серверов MS SQL.
В самом Delphi это реализовано!! Если в adoconnection.connectionstring выбрать пункт microsoft ole db provider for sql server, диалоговое окно попросит ввести или выбрать имя сервера (причем если в сети есть запущенные sql серверы, то они будут представлены в выпадающем списке)
Как это сделать самому??

В интернете есть информация про следующие варианты
.NET 2.0: SqlDataSourceEnumerator
SMO - SmoApplication.EnumAvailableSqlServers(False)
SQLDMO (COM Interop) - ListAvailableSQLServers
ODBC - SQLBrowseConnect
NetBios
DbLibrary, реестр Windows

Но не один из этих вариантов нигде подробно не описан! Пожалуйста помогите разобраться!
Ответить с цитированием
  #2  
Старый 04.12.2009, 12:38
Аватар для Aristarh Dark
Aristarh Dark Aristarh Dark вне форума
Модератор
 
Регистрация: 07.10.2005
Адрес: Москва
Сообщения: 2,906
Версия Delphi: Delphi XE
Репутация: выкл
По умолчанию

Код:
procedure GetServerList(Strings: TStrings);
var
  dmo:OleVariant;
  i:Integer;
begin
  Strings.Clear;
  try
    dmo:=CreateOleObject('SQLDMO.SQLServer');
    dmo:=dmo.Application;
    dmo:=dmo.ListAvailableSQLServers;
    for i:=1 to dmo.Count do
      if (Length(trim(dmo.Item(i))) > 0) and (CompareText(dmo.Item(i),'(LOCAL)')<>0) then
        Strings.Add(AnsiUpperCase(dmo.Item(i)));
   except
   end;
end;

Как видно из кода, локальный сервер (т.е. установленный на машине с которой идет запрос) в список не выводится. И еще, в 2005 MS SQL DMO вроде как упразднили, поэтому код работать не будет
__________________
Некоторые программисты настолько ленивы, что сразу пишут рабочий код.

Если вас наказали ни за что - радуйтесь: вы ни в чем не виноваты.
Ответить с цитированием
  #3  
Старый 04.12.2009, 16:05
PavluxaF PavluxaF вне форума
Прохожий
 
Регистрация: 04.05.2009
Сообщения: 9
Репутация: 10
По умолчанию

У меня сервер 2008 и DMO не работает.
Delphi долго удивляется что это за OLE-объект и выдает ошибку!
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 16:44.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter