上一篇文章展示了使用COM对象如何列出局域网中的 SQL Server服务器信息,后来还发现在.Net中有现成的类可用,而不需要使用不太熟悉的COM对象了,这样岂不是更好?下面我把代码展示给大家:
using System;
using System.Data.Sql;
using System.Text;

namespace AllSqlServer
{
    class Program
    {
        static void Main(string[] args)
        {
            //SQLDMO.NameList names;
            //SQLDMO.ApplicationClass ac = new SQLDMO.ApplicationClass();
            //names = ac.ListAvailableSQLServers();
            //string[] serverList = new string[names.Count];
            //for (int i = 0; i < serverList.Length; i++)
            //{
            //    serverList[i] = names.Item(i);
            //}
            //foreach (string str in serverList)
            //{
            //    Console.WriteLine(str);
            //}

            SqlDataSourceEnumerator instance =SqlDataSourceEnumerator.Instance;
            System.Data.DataTable table = instance.GetDataSources();

            DisplayData(table);

            Console.ReadLine();
        }

        private static void DisplayData(System.Data.DataTable table)
        {
            foreach (System.Data.DataRow row in table.Rows)
            {
                Console.WriteLine("服务器名 = {0}", row["ServerName"]);
                Console.WriteLine("实例名 = {0}", row["InstanceName"]);
                Console.WriteLine("是否是群集服务器 = {0}", row["IsClustered"]);//指示服务器是否是群集的一部分
                Console.WriteLine("版本 = {0}", row["Version"]);//8.*是SQL 2000,9.*是SQL 2005
                Console.WriteLine("============================");
            }
        }
    }
}

相关文章:

  • 2021-08-17
  • 2022-02-07
  • 2021-08-04
  • 2021-11-05
  • 2021-11-30
  • 2021-11-04
  • 2022-12-23
  • 2021-12-23
猜你喜欢
  • 2022-02-22
  • 2021-12-12
  • 2021-08-15
  • 2021-10-15
  • 2022-12-23
  • 2021-06-29
相关资源
相似解决方案