亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

用API得到局域網中可用SqlServer服務器列表

2019-11-18 19:24:48
字體:
來源:轉載
供稿:網友

    無意中找到了以前的一個C#程序,覺得好用發到這里以便和大家共享一下,其實這個代碼我是抄別人過來的,原作者不詳,覺得寫的好就和大家共享一下了程序實現了用API來得到SqlServer服務器列表的功能,我覺得比用SQLDEMO組件更有意義,代碼如下:


/// <summary>

/// 獲取網內的數據庫服務器名稱

/// </summary>

public class SqlLocator

{

     [System.Runtime.InteropServices.DllImport("odbc32.dll")]

     PRivate static extern short SQLAllocHandle(short hType, IntPtr inputHandle, out IntPtr outputHandle);

     [System.Runtime.InteropServices.DllImport("odbc32.dll")]

     private static extern short SQLSetEnvAttr(IntPtr henv, int attribute, IntPtr valuePtr, int strLength);

     [System.Runtime.InteropServices.DllImport("odbc32.dll")]

     private static extern short SQLFreeHandle(short hType, IntPtr handle);

     [System.Runtime.InteropServices.DllImport("odbc32.dll",CharSet= System.Runtime.InteropServices.CharSet.Ansi)]

     private static extern short SQLBrowseConnect(IntPtr hconn, System.Text.StringBuilder inString,

         short inStringLength, System.Text.StringBuilder outString, short outStringLength,

         out short outLengthNeeded);

 

     private const short SQL_HANDLE_ENV = 1;

     private const short SQL_HANDLE_DBC = 2;

     private const int SQL_ATTR_ODBC_VERSION = 200;

     private const int SQL_OV_ODBC3 = 3;

     private const short SQL_SUCCESS = 0;

 

     private const short SQL_NEED_DATA = 99;

     private const short DEFAULT_RESULT_SIZE = 1024;

     private const string SQL_DRIVER_STR = "DRIVER=SQL SERVER";

 

     private SqlLocator(){}

 

     /// <summary>

     /// 獲取網內的數據庫服務器名稱,是一個字符串數組。

     /// </summary>

     /// <returns></returns>

     public static string[] GetServers()

     {

         string list = string.Empty;

         IntPtr henv = IntPtr.Zero;

         IntPtr hconn = IntPtr.Zero;

         System.Text.StringBuilder inString = new System.Text.StringBuilder(SQL_DRIVER_STR);

         System.Text.StringBuilder outString = new System.Text.StringBuilder(DEFAULT_RESULT_SIZE);

         short inStringLength = (short) inString.Length;

         short lenNeeded = 0;

 

         try

         {

              if (SQL_SUCCESS == SQLAllocHandle(SQL_HANDLE_ENV, henv, out henv))

              {

                   if (SQL_SUCCESS == SQLSetEnvAttr(henv,SQL_ATTR_ODBC_VERSION,(IntPtr)SQL_OV_ODBC3,0))

                   {

                       if (SQL_SUCCESS == SQLAllocHandle(SQL_HANDLE_DBC, henv, out hconn))

                       {

                            if (SQL_NEED_DATA ==  SQLBrowseConnect(hconn, inString, inStringLength, outString,

                                 DEFAULT_RESULT_SIZE, out lenNeeded))

                            {

                                 if (DEFAULT_RESULT_SIZE < lenNeeded)

                                 {

                                     outString.Capacity = lenNeeded;

                                     if (SQL_NEED_DATA != SQLBrowseConnect(hconn, inString, inStringLength, outString,

                                          lenNeeded,out lenNeeded))

                                     {

                                          throw new applicationException("Unabled to aquire SQL Servers from ODBC driver.");

                                     }   

                                 }

                                 list = outString.ToString();

                                 int start = list.IndexOf("{") + 1;

                                 int len = list.IndexOf("}") - start;

                                 if ((start > 0) && (len > 0))

                                 {

                                     list = list.Substring(start,len);

                                 }

                                 else

                                 {

                                     list = string.Empty;

                                 }

                            }                          

                        }

                   }

              }

         }

         catch

         {

              list = string.Empty;

         }

         finally

         {

              if (hconn != IntPtr.Zero)

              {

                   SQLFreeHandle(SQL_HANDLE_DBC,hconn);

              }

              if (henv != IntPtr.Zero)

              {

                   SQLFreeHandle(SQL_HANDLE_ENV,hconn);

              }

         }

 

         string[] array = null;

 

         if (list.Length > 0)

         {

              array = list.Split(',');

         }

 

         return array;

     }

}


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲一区二区日本| 中文字幕在线观看日韩| 国产精品成人一区二区三区吃奶| 国产欧美在线观看| 欧美激情第三页| 亚洲va久久久噜噜噜久久天堂| 91夜夜揉人人捏人人添红杏| 久久久免费精品视频| 欧美人在线观看| 欧美一级片一区| 精品国产美女在线| 九九九久久久久久| 精品国产乱码久久久久久虫虫漫画| 国产精品一久久香蕉国产线看观看| 国产做受高潮69| 欧美成人精品不卡视频在线观看| 国产精品三级久久久久久电影| 亚洲福利视频专区| 成人羞羞国产免费| 亚洲视屏在线播放| 色悠悠久久久久| 欧美激情精品久久久久久免费印度| 国产精品一区二区久久国产| 国产一区二区动漫| 91精品国产综合久久香蕉的用户体验| 色午夜这里只有精品| 91美女福利视频高清| 国产91精品久久久久久久| 亚洲成人激情在线观看| 欧美精品成人91久久久久久久| 欧美成人精品一区| 久久五月天色综合| 国产一区二区三区网站| 久久精品国产久精国产一老狼| 中文字幕精品影院| 国产99久久久欧美黑人| 久久久久九九九九| 福利二区91精品bt7086| 国产成人综合精品在线| 国产精品美腿一区在线看| 国产综合视频在线观看| 亚洲欧美中文日韩在线v日本| 欧美劲爆第一页| 欧美性xxxx极品hd满灌| 国产一区二中文字幕在线看| 亚洲乱码av中文一区二区| 欧美电影免费观看网站| 日本国产高清不卡| 俺去亚洲欧洲欧美日韩| 亚洲一区二区三区在线免费观看| 亚洲色图综合久久| 亚洲电影免费观看高清完整版在线| 97高清免费视频| 亚洲电影在线看| 欧美日韩中文字幕日韩欧美| 亚洲精品一区中文字幕乱码| 欧美一级淫片播放口| 欧美裸体xxxxx| 精品一区二区三区电影| 欧美中文在线观看| 中文字幕欧美日韩在线| 亚洲风情亚aⅴ在线发布| 97视频色精品| 久久久精品亚洲| 国产精品入口福利| 欧美成aaa人片在线观看蜜臀| 日本成人在线视频网址| 国模精品视频一区二区| 亚洲 日韩 国产第一| 亚洲一品av免费观看| 韩剧1988在线观看免费完整版| 中文字幕亚洲专区| 2019国产精品自在线拍国产不卡| 日韩av日韩在线观看| 久久久免费av| 亚洲女人天堂视频| 国产精品第1页| 亚洲a区在线视频| 日韩亚洲精品电影| 91国产一区在线| 日韩欧美亚洲综合| 成人黄色网免费| 欧美极品少妇xxxxⅹ喷水| 久久精品国产欧美亚洲人人爽| 日韩成人在线视频观看| 亚洲欧美资源在线| 日韩在线观看网站| 国产成人精品优优av| 日韩一区二区欧美| 国产日韩欧美在线观看| 欧美国产在线视频| 国产精品av在线| 欧美国产日韩xxxxx| 欧美激情视频三区| 欧美精品一区二区三区国产精品| 亚洲成人aaa| 欧美大秀在线观看| 国产一区二区三区视频| 久久久日本电影| 日韩成人小视频| 日韩在线中文视频| 色偷偷偷亚洲综合网另类| 国产91在线高潮白浆在线观看| 亚洲精品短视频| 久久躁狠狠躁夜夜爽| 日韩av中文字幕在线免费观看| 日韩av中文字幕在线| 好吊成人免视频| 亚洲国产精品推荐| 日本中文字幕成人| 中文字幕久热精品在线视频| 欧美国产高跟鞋裸体秀xxxhd| 成人黄色在线免费| 亚洲第一网中文字幕| 国产视频自拍一区| 欧美性jizz18性欧美| 国产精品在线看| 狠狠综合久久av一区二区小说| 久久久久亚洲精品国产| 清纯唯美日韩制服另类| 欧美电影电视剧在线观看| 亚洲天堂免费视频| 亚洲自拍偷拍网址| 91久久精品视频| 久久久国产一区二区| 欧美激情手机在线视频| 亚州国产精品久久久| 亚洲精品一区中文字幕乱码| 国产精品稀缺呦系列在线| 最近2019年好看中文字幕视频| 欧美一区二区影院| 中文字幕日韩视频| 亚洲国产精久久久久久久| 欧美成人在线免费| 亚洲视频在线观看免费| 91精品国产777在线观看| 欧美极品少妇全裸体| 欧美亚洲另类激情另类| 日韩在线小视频| 最近2019中文免费高清视频观看www99| 在线观看欧美视频| 俺也去精品视频在线观看| 91精品在线观看视频| 色狠狠av一区二区三区香蕉蜜桃| 国产日韩在线免费| 日韩av一区二区在线| 久久精品电影网| 亚洲最新av在线| 亚洲大胆美女视频| 日韩欧美在线视频免费观看| 亚洲午夜av电影| 欧美日韩亚洲一区二区| 国产视频精品va久久久久久| 热门国产精品亚洲第一区在线| 国产在线日韩在线| www.日韩.com| 欧美国产日韩精品| 国产99久久精品一区二区| 久久久91精品国产一区不卡| 97精品久久久中文字幕免费| 国产69精品久久久久9999| 久久久女女女女999久久| 国产成人综合精品| 亚洲人成在线电影|