我编了一个对话框,想让用户输入SqlServer的一些参数,比如:IP,用户名,密码。但是怎样得到一个局域网内部所有可用的SQLServer,应该怎么写程序呢?要考虑那些啊?VC6.0

解决方案 »

  1.   

    在msdn有
    用NetServerEnum
    下面的代码中
       DWORD dwServerType = SV_TYPE_SERVER;
    改成SV_TYPE_SQLSERVER;好像就可以了#ifndef UNICODE
    #define UNICODE
    #endif#include "stdafx.h"
    #include <stdio.h>
    #include <assert.h>
    #include <windows.h> 
    #include <lm.h>
    #pragma  comment(lib,"netapi32")  
    int wmain(int argc, wchar_t *argv[])
    {
       LPSERVER_INFO_101 pBuf = NULL;
       LPSERVER_INFO_101 pTmpBuf;
       DWORD dwLevel = 101;
       DWORD dwPrefMaxLen = MAX_PREFERRED_LENGTH;
       DWORD dwEntriesRead = 0;
       DWORD dwTotalEntries = 0;
       DWORD dwTotalCount = 0;
       DWORD dwServerType = SV_TYPE_SERVER;//SV_TYPE_SERVER; // all servers
       DWORD dwResumeHandle = 0;
       NET_API_STATUS nStatus;
       LPTSTR pszServerName = NULL;
       DWORD i;   if (argc > 2)
       {
          fwprintf(stderr, L"Usage: %s [\\\\ServerName]\n", argv[0]);
          return (1);
       }
       // The server is not the default local computer.
       //
       if (argc == 2)
          pszServerName = (char*)argv[1];
       //
       // Call the NetServerEnum function to retrieve information
       //  for all servers, specifying information level 101.
       //
       nStatus = NetServerEnum((const unsigned short*)pszServerName,
                               dwLevel,
                               (LPBYTE *) &pBuf,
                               dwPrefMaxLen,
                               &dwEntriesRead,
                               &dwTotalEntries,
                               dwServerType,
                               NULL,
                               &dwResumeHandle);
       //
       // If the call succeeds,
       //
       if ((nStatus == NERR_Success) || (nStatus == ERROR_MORE_DATA))
       {
          if ((pTmpBuf = pBuf) != NULL)
          {
             //
             // Loop through the entries and 
             //  print the data for all server types.
             //
             for (i = 0; i < dwEntriesRead; i++)
             {
                assert(pTmpBuf != NULL);            if (pTmpBuf == NULL)
                {
                   fprintf(stderr, "An access violation has occurred\n");
                   break;
                }            printf("\tPlatform: %d\n", pTmpBuf->sv101_platform_id);
                wprintf(L"\tName:     %s\n", pTmpBuf->sv101_name);
                printf("\tVersion:  %d.%d\n",
                       pTmpBuf->sv101_version_major,
                       pTmpBuf->sv101_version_minor);
                printf("\tType:     %d", pTmpBuf->sv101_type);
                //
                // Check to see if the server is a domain controller;
                //  if so, identify it as a PDC or a BDC.
                //
                if (pTmpBuf->sv101_type & SV_TYPE_DOMAIN_CTRL)
                   wprintf(L" (PDC)");
                else if (pTmpBuf->sv101_type & SV_TYPE_DOMAIN_BAKCTRL)
                   wprintf(L" (BDC)");
                
                printf("\n");
                //
                // Also print the comment associated with the server.
                //
                wprintf(L"\tComment:  %s\n\n", pTmpBuf->sv101_comment);            pTmpBuf++;
                dwTotalCount++;
             }
             // Display a warning if all available entries were
             //  not enumerated, print the number actually 
             //  enumerated, and the total number available.         if (nStatus == ERROR_MORE_DATA)
             {
                fprintf(stderr, "\nMore entries available!!!\n");
                fprintf(stderr, "Total entries: %d", dwTotalEntries);
             }         printf("\nEntries enumerated: %d\n", dwTotalCount);
          }
       }
       else
          fprintf(stderr, "A system error has occurred: %d\n", nStatus);
       //
       // Free the allocated buffer.
       //
       if (pBuf != NULL)
          NetApiBufferFree(pBuf);   return 0;
    }