如何搜索出局域网上所有运行的SQL SERVER及实例

hljalong 2006-06-28 03:36:10
我在发此贴前搜索了一下,已有如下进展:
1.知道用NetServerEnum()函数,使用SV_TYPE_SQLSERER参数,可以获得局域网上的运行SQL SERVER的电脑的名称及平台版本信息。
2.用1中的信息可以去连接安装了SQL SERVER的电脑上的SQLSERVER。因为这时使用得到的电脑的名称作为SQL SERVER就可以。

新的问题来了,如果一台电脑上安装并运行的是SQL SERVER的一个命名实例,这个函数返回来的信息就不够用了。例如:一台电脑名称为TEST,其上安装了一个名为SaleDB的SQL SERVER实例,那么在连接时要这样指定SERVER=TEST\SaleDB才能正常连接,只是指定TEST是无法连接成功的。也就是说,应该有一个方法,不仅能知道局域网上运行SQL SERVER的电脑,还要能从那些电脑上得到正在运行的实例的名字。

综上所述,我要知道的是如何在一个已知运行了SQL SERVER的电脑上取得其实例的名称。
...全文
142 4 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
hljalong 2006-06-28
  • 打赏
  • 举报
回复
to xazl(西北狼),gao_ming77(小明)

你们同时要我使用SQL-DMO,这个其实我也看到了,我只所以没提,是因为我发现这个要求一个sqldmo.rll文件支持,而这个文件不是系统自带的,而是SQL SERVER的一个文件,也就是说,只有安装了SQL SERVER的电脑才有会有这个文件(当然,我也可以在自己写的程序发布时带上这个文件)。但是,当我看到一个没有安装SQL SERVER的电脑,也就是说那台电脑中没有sqldmo.rll文件,在program files下连Microsoft SQL文件都没有,但是控制面板中的数据源(ODBC)中在添加数据源的对话框中依然可以把局域网中的所有运行的SQL SERVER及实例在下拉列表框中全部列出。所以我觉得应该有一个用API实现的方法来完成我想要的功能。

to laiyiling(【陌生人.MVP】)
你告诉我的地方我已经看到过了,你觉得你说的那个地方除了用了我说的NetServerEnum函数之外还用了什么特别的函数吗?我没看到。而且我用这个函数是无法得到SQL SERVER实例名称的。
Kudeet 2006-06-28
  • 打赏
  • 举报
回复
http://community.csdn.net/Expert/FAQ/FAQ_Index.asp?id=196971
gao_ming77 2006-06-28
  • 打赏
  • 举报
回复
用SQLDMO
#import "C:\Program Files\Microsoft SQL Server\80\Tools\Binn\Resources\1033\sqldmo.rll" no_namespace

try
{
_SQLServerPtr spSQLServer;

HRESULT hr2 = spSQLServer.CreateInstance(__uuidof(SQLServer));
if (SUCCEEDED(hr2))
{
try
{
// Get the Application Ptr
long lServerCount;
_ApplicationPtr pApplication = spSQLServer->GetApplication();
if (pApplication)
{
NameListPtr pServerNameList = pApplication->ListAvailableSQLServers();
if (pServerNameList)
{
lServerCount = pServerNameList->Count;
for (long i=0; i < lServerCount; i++)
{
_bstr_t bstrValue(pServerNameList->Item( i ));
CString sName((LPCSTR)bstrValue);
if (!sName.IsEmpty())
m_ctlComboBox.AddString(sName);
}
}
}
pApplication = NULL;

spSQLServer.Release();
}
catch (_com_error e)
{
spSQLServer.Release();
}
}
else
{
AfxMessageBox("Create Error.");
}
}
catch (_com_error e)
{
AfxMessageBox("Error");
}
xazl 2006-06-28
  • 打赏
  • 举报
回复
http://kb.csdn.net/.net/Articles/200507/cfa8f5cc-fc77-4b6e-ad88-9de757b5d2de.html
http://msdn2.microsoft.com/en-us/library/ms140744.aspx


HRESULT ListAvailableSQLServers(
LPSQLDMONAMELIST* ppServerNames);

Returns

A NameList object that enumerates instances of SQL Server.

Remarks

Nondefault instances of SQL Server are displayed in the form of SERVERNAME/INSTANCENAME.

16,547

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • AIGC Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧