SQLServer2008远程连接

10 篇文章 0 订阅
3 篇文章 0 订阅

Vc++(MFC)

实现

SQL 

Server

的远程连接(

ADO

实现)

 

 

ADO

 

       ADO

Microsoft

访

 

OLE DB 

便

使

OLE.DB 

访

ADO 

使

、速

、内

使

OLE 

 

ADO

SQL Server

 

1

ADO

      

使

ADO

stdafx.h

#import

A

 

#include <comdef.h> 

#include <icrsint.h> 

#import "C:\program files\common files\system\ado\msado15.dll" \ 

         no_namespace rename("EOF", "ADOEOF")     

使

ADO

,但

使

ADO

"ADOEOF"

使

ADO

 

2

OLE/COM

    

InitInstance()

OLE/COM

 

BOOL ****** ::InitInstance

 

      

 //

 

    

 if (!AfxOleInit())//

OLE/COM

         

   { 

        AfxMessageBox("OLE

"); 

         return FALSE; 

    }

 

      ................

 

3

 

_ConnectionPtr

_RecordsetPtr

 

_ConnectionPtr

 m_pConnection;  

 

_RecordsetPtr

 m_pRecordset; 

 

HRESULT 

hr; 

try 

   hr = m_pConnection.CreateInstance("ADODB.Connection");

 

   if (

SUCCEEDED(hr

)) 

   {  

            //connect database 

    

   

_bstr_t

 

strConnect="Provider=SQLOLEDB.1;Initial Catalog=“

”;Data Source=

IP"; 

          hr = 

m_pConnection->Open(

strConnect,"

","

",

adModeUnknown

); 

    AfxMessageBox("

"); 

   } 

   

catch

 

(_com_error e

  

CString 

errormessage; 

   errormessage.Format("

\r\n

:%s",e.ErrorMessage());

 

   AfxMessageBox(errormessage); 

   return  

4

 

listctrl

m_list 

winfo

id

name

ip

 

listctrl

 

m_list.InsertColumn(0,"ID"); 

m_list.InsertColumn(1,"Name"); 

m_list.InsertColumn(1,"IP"); 

CRect rect3; 

m_list.GetClientRect(rect3); 

m_list.SetColumnW

idth(0,rect3.W

idth()/3);

 

m_list.SetColumnW

idth(1,rect3.W

idth()/3);

 

m_list.SetColumnW

idth(2,rect3.W

idth()/3);

 

 

int intm; 

try 

   

_variant_t

 RecordsAffected;  

   m_pRecordset = 

m_pConnection->Execute

("

SELECT

 id

name

ip 

from

   winfo",&RecordsAffected,adC

   while(!m_pRecordset->ADOEOF) 

   { 

   

_variant_t

 ID, Name, IP; 

    ID= 

m_pRecordset->GetCollect

("id"); 

    Name=

m_pRecordset->GetCollect

("name"); 

    IP=

m_pRecordset->GetCollect

("ip"); 

    intm=m_list.InsertItem(0,(_bstr_t)ID);

 

    m_list.SetItem(intm,1,1,(_bstr_t)IP,NULL,0,0,0);

 

    m_list.SetItem(intm,2,1,(_bstr_t)Name,NULL,0,0,0); 

    m_pRecordset->MoveNext(); 

   } 

   m_pRecordset->Close(); 

   catch (_com_error e) 

   { 

    CString errormessage; 

    errormessage.Format("

\r\n

:%s",e.ErrorMessage());

 

    AfxMessageBox(errormessage); 

   return  

   } 

id 

name 

ip

listctr

 

5

 

 

       

COM

使

CString 

COM

COM

C++

_vatiant_t

_bstr_t

COM

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值