【问题标题】:Retrieve SQL Protocol Status检索 SQL 协议状态
【发布时间】:2012-04-24 06:36:41
【问题描述】:

使用 SQL 查询或 WMI,我想检索 SQL 协议(如 Named Pipes、TCP/IP)是否启用。

我需要为 SQL Server 2000、2005、2008 执行此操作。

谢谢。

【问题讨论】:

    标签: sql sql-server-2008 sql-server-2005 wmi wmi-query


    【解决方案1】:

    WMI Provider for Configuration Management Classes 包括ServerNetworkProtocol WMI 类,它列出了Microsoft SQL Server 实例上安装的协议,该类位于root\Microsoft\SqlServer\ComputerManagement10 命名空间中(对于sql server 2008,在其他版本中您必须修改命名空间)。

    检查这个 C# 示例

    using System;
    using System.Collections.Generic;
    using System.Management;
    using System.Text;
    
    namespace GetWMI_Info
    {
        class Program
        {
    
            static void Main(string[] args)
            {
                try
                {
                    string ComputerName = "localhost";
                    ManagementScope Scope;                
    
                    if (!ComputerName.Equals("localhost", StringComparison.OrdinalIgnoreCase)) 
                    {
                        ConnectionOptions Conn = new ConnectionOptions();
                        Conn.Username  = "";
                        Conn.Password  = "";
                        Conn.Authority = "ntlmdomain:DOMAIN";
                        Scope = new ManagementScope(String.Format("\\\\{0}\\root\\Microsoft\\SqlServer\\ComputerManagement10", ComputerName), Conn);
                    }
                    else
                        Scope = new ManagementScope(String.Format("\\\\{0}\\root\\Microsoft\\SqlServer\\ComputerManagement10", ComputerName), null);
    
                    Scope.Connect();
                    ObjectQuery Query = new ObjectQuery("SELECT * FROM ServerNetworkProtocol");
                    ManagementObjectSearcher Searcher = new ManagementObjectSearcher(Scope, Query);
    
                    foreach (ManagementObject WmiObject in Searcher.Get())
                    {
                        Console.WriteLine("{0,-35} {1,-40}","ProtocolDisplayName",WmiObject["ProtocolDisplayName"]);// String
                        Console.WriteLine("{0,-35} {1,-40}","Enabled",WmiObject["Enabled"]);// Boolean
                        Console.WriteLine("{0,-35} {1,-40}","InstanceName",WmiObject["InstanceName"]);// String
                        Console.WriteLine("{0,-35} {1,-40}","MultiIpConfigurationSupport",WmiObject["MultiIpConfigurationSupport"]);// Boolean
                        Console.WriteLine("{0,-35} {1,-40}","ProtocolName",WmiObject["ProtocolName"]);// String
                        Console.WriteLine();
    
    
                    }
                }
                catch (Exception e)
                {
                    Console.WriteLine(String.Format("Exception {0} Trace {1}",e.Message,e.StackTrace));
                }
                Console.WriteLine("Press Enter to exit");
                Console.Read();
            }
        }
    }
    

    这将返回类似这样的内容

    ProtocolDisplayName                 Shared Memory
    Enabled                             True
    InstanceName                        MSSQLSERVER
    MultiIpConfigurationSupport         False
    ProtocolName                        Sm
    
    ProtocolDisplayName                 Named Pipes
    Enabled                             False
    InstanceName                        MSSQLSERVER
    MultiIpConfigurationSupport         False
    ProtocolName                        Np
    
    ProtocolDisplayName                 TCP/IP
    Enabled                             True
    InstanceName                        MSSQLSERVER
    MultiIpConfigurationSupport         True
    ProtocolName                        Tcp
    
    ProtocolDisplayName                 VIA
    Enabled                             False
    InstanceName                        MSSQLSERVER
    MultiIpConfigurationSupport         False
    ProtocolName                        Via
    

    【讨论】:

    • 感谢帮助,但上面的代码在我的 Windows Server 2008 64 位中引发错误。
    • @John,这个错误是因为你使用了一个无效的命名空间,SQL Server 2005 使用ComputerManagement,SQL Server2008 使用ComputerManagement10,SQL Server 2012 使用ComputerManagement11
    猜你喜欢
    • 2011-08-15
    • 2013-05-24
    • 1970-01-01
    • 2011-08-11
    • 2016-07-10
    • 2012-09-29
    • 2013-11-22
    • 1970-01-01
    • 2018-01-23
    相关资源
    最近更新 更多