0

SQL クエリまたは WMI を使用して、名前付きパイプ、TCP/IP などの SQL プロトコルが有効になっているかどうかを取得したいと考えています。

SQL Server 2000、2005、2008 でこれを行う必要があります。

ありがとうございました。

4

1 に答える 1

1

構成管理クラスのWMI プロバイダーにServerNetworkProtocolは、Microsoft SQL Server のインスタンスにインストールされているプロトコルを一覧表示する WMI クラスが含まれています。このクラスは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
于 2012-04-24T06:49:56.317 に答える