5

我们有一些代码来识别返回意外结果的 SQL Server 实例及其关联的 Reporting Server 实例。

一台机器有两个实例SQL Express (2008) - (local)/SQLEXPRESS(local)/EXPRESS_BOB- 每个实例都有自己的报告服务器。

使用 WMI,我们识别 SQL Server 实例,这按预期工作。然后,对于每个实例,我们查询 RS 实例,如下所示:

public void QueryServers(string wmiPath)
{
    using (
        var searcher = new ManagementObjectSearcher(
           wmiPath, 
           "Select * from MSReportServer_ConfigurationSetting"))
    {
        ManagementObjectCollection moc = searcher.Get();
        //
        // Process objects in moc
        //
    }
}

这是针对 wmiPath 的两个值运行的(注意 - 需要以管理员身份运行):

  • wmiPath = "root\Microsoft\SqlServer\ReportServer\RS_SQLEXPRESS\v10\Admin"
  • wmiPath = "root\Microsoft\SqlServer\ReportServer\RS_EXPRESS_5fBOB\v10\Admin"

无论 的值如何wmiPathmoc集合始终包含两个值:

  • moc[0] ["InstanceName"] = "SQLEXPRESS"
  • moc[1] ["InstanceName"] = "EXPRESS_BOB"

指定 SQL Server 实例的 WMI 路径下的查询如何返回(我希望)存在于不同路径下的 Report Server 实例?

这是查询的正确路径吗?

4

1 回答 1

3

它似乎是设计使然(请参阅http://msdn.microsoft.com/en-us/library/ms152836.aspx

添加"Where InstanceName='<instance name>'"到查询可能会有所帮助

于 2012-08-07T05:44:25.513 回答