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

Вниз

как работать с SQL-DMO   Найти похожие ветки 

 
victor_ch   (2003-09-14 14:26) [0]

Добрый день Всем!!!

нашел я как то кусок кода который вытаскивает список MSSQL серверов в локальной сети, но к нему была приписка что этот код будет работать при установленном SQL-DMO
я попробовал, у меня не получилось и вот теперь не понятно установлен ли на моей машине этот самый SQL-DMO (подскажите как это можно узнать) и если установлен то надо ли его как то подключать в Delphi (как это делается в Visual Basic)


 
sniknik ©   (2003-09-14 16:33) [1]

var Application: OleVariant;
begin
try
try
Application:= CreateOleObject("SQLDMO.Application");
except
on E: Exception do //неустановлен // или просто глючит
end;
finally
Application:= Unassigned;
end;
end;


 
victor_ch   (2003-09-14 17:34) [2]

при проверке кодом от
> sniknik © (14.09.03 16:33) [1]


получилось что SQLDMO установлен, но почему тогда
не выдается список серверов в сети
код для этого использую следующий

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;


 
sniknik ©   (2003-09-14 19:04) [3]

может потому что нет установленных SQL серверов в сети? убери условие хотя бы себя видеть будеш если конечно имеемся MSSQL на локали.

и кстати поправь немного код (мне кажется так будет лутше)

procedure GetServerList(Strings: TStrings);
var app, dmo:OleVariant;
i:Integer;
begin
Strings.Clear;
app:=CreateOleObject("SQLDMO.Application");
try
dmo:=app.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)));
finally
app:= Unassigned;
end;
end;


 
victor_ch   (2003-09-15 23:54) [4]

код подправил
но у меня цикл for не выполняется не разу
потому что dmo.count=0 хотя в локальной сети точно есть 2 MSSQL сервера, может дело в версии MSSQL у нас стоит 7 версия?


 
Плохиш_   (2003-09-16 00:10) [5]

К сожалению, ДМО выдаёт список только SQL-серверов своей версии :-(


 
victor_ch   (2003-09-16 00:36) [6]


> К сожалению, ДМО выдаёт список только SQL-серверов своей
> версии :-(

а от чего зависит версия DMO? как я понимаю она должна поставляться вместе с клиентом MSSQL, но у нас тогда одинаковая версия, клиента и сервера потому что мы ставили все с одного диска


 
jocko ©   (2003-09-16 10:47) [7]

Попробуй импортировать саму библиотеку в дельфи,
возможно в ранней версии dmo ListAvailableSQLServers по другому назыался, или может есть альтернативный метод...



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

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

Наверх




Память: 0.48 MB
Время: 0.032 c
1-18321
sashcan
2003-09-23 20:15
2003.10.06
реестр Windows


1-18460
LinOS
2003-09-26 05:35
2003.10.06
Как определить что форма создана


1-18384
DreamDesire
2003-09-22 17:16
2003.10.06
Область прокрутки для компонентов


3-18256
Andrey V.
2003-09-15 14:57
2003.10.06
ib vs. fb


1-18313
muzik
2003-09-23 18:29
2003.10.06
Редактор свойств