首页 VC++与ADO对数据库的链接

VC++与ADO对数据库的链接

举报
开通vip

VC++与ADO对数据库的链接PAGE\*MERGEFORMAT#/8ADO数据库编程-总结1一、数据库操作准备1、导入ADO动态链接库在工程的stdafx.h中加入如下语句:#import"c:\programfiles\commonfiles\system\ado\msado15.dll"no_namespace\rename("EOF","adoEOF")这一语句有何作用呢?其最终作用同我们熟悉的#inelude类似,编译的时候系统会为我们生成msado15.tlh和ado15.tli两个C++头文件来定义ADO库,即加载ADO动态...

VC++与ADO对数据库的链接
PAGE\*MERGEFORMAT#/8ADO数据库编程- 总结 初级经济法重点总结下载党员个人总结TXt高中句型全总结.doc高中句型全总结.doc理论力学知识点总结pdf 1一、数据库操作准备1、导入ADO动态链接库在工程的stdafx.h中加入如下语句:#import"c:\programfiles\commonfiles\system\ado\msado15.dll"no_namespace\rename("EOF","adoEOF")这一语句有何作用呢?其最终作用同我们熟悉的#inelude类似,编译的时候系统会为我们生成msado15.tlh和ado15.tli两个C++头文件来定义ADO库,即加载ADO动态库(msado15.dll)。其中,no_namespace 关于同志近三年现实表现材料材料类招标技术评分表图表与交易pdf视力表打印pdf用图表说话 pdf 明不使用命名空间,rename("EOF","adoEOF")表明把ADO中用到的EOF改为adoEOF,防止发生命名冲突。注意:该代码需要在一行中完成,如果写成两行或者多行,行末要加上“'符号,表示把这几行看成一行,如本例。2、初始化OLE/COM库环境在基于MFC的应用里,初始化OLE/COM库环境的一个比较好的位置是在应用类的InitInstanee成员函数中,而且直接使用AfxOlelnit,在退出应用时,该函数也负责COM资源的释放,将此函数添加在InitInstanee中的如下位置:BOOLCExpApp::lnitlnstance(){AfxEnableControlContainer();//初始化OLEDLLsif(!AfxOleInit()){AfxMessageBox("初始化OLEDLL失败!");ReturnFALSE;}}说明:也可以在InitInstanee中使用::CoInitialize初始化OLE/COM库环境,但须在ExitInitlnstanee中使用::CoUninitialize释放占用的COM资源,显然使用AfxOleInit更为方便。3、连接数据库在DocWiew程序中,通常在应用类(App类)中进行数据库的连接。1)声明一个Connection指针_ConnectionPtrm_pConnection;注:ADO最重要的三个对象有三个:连接对象(Conneetion)、命令对象(Command)和记录集对象(RecordSet)。在使用这三个对象的时候,需要定义与之相对应的智能指针,分别为_ConneetionPtr、_CommandPtr、_RecordsetPtr。由上述ConneetionPtr指针的使用步骤可知,和C++中的类指针使用方法一样,智能指针也要先定义指针变量、创建其实例(实例化),然后就可以调用它的方法和属性。不同的是,该智能指针最后是自动进行内存释放的。所有的智能指针都是基于_eom_ptr_t模板类的,该类封装了lUnknow接口的3个方法:QueryInterface、Addref和Release。它具有自动计数的机制,即在构造对象时,自动为该对象计数加1。析构对象时,自动调用Release方法。(即该类型的指针在使用后不需要手动释放内存)(但需要调用Close方法,关闭连接或者记录集)所以智能指针会使代码更加简洁并且不易出错。2)创建Connection对象m_pConnection.Createlnstance(__uuidof(Connection));m_pConnection.Createlnstance("ADODB.Connection");上述两种方法均可。注意:上面调用_ConnectionPtr接口指针的方法Createlnstanee时,用的是"而非->”。3)设置连接字符串,以便指定需要的连接使用JET数据库引擎实现对Acess2000类型的数据库info.mdb的连接CStringstrSQL="Provider=Microsoft.Jet.OLEDB.4.0;DataSource=info.mdb;UserID=admin;Passward=;”;或者CStringstrSQL=_T("Provider=Microsoft.Jet.OLEDB.4.0;DataSource=info.mdb;UserID=admin;Passward=;");使用OLEDB提供者实现对SQLServer的标准安全连接串strConnect=_T("Provider=sqloledb;DataSource=MyServerName;""InitialCatalog=MyDateBaseName;""UserID=MyUserName;Password=MyPassword;");如果是sql2000Provider=SQLOLEDB.1;PersistSecurityInfo=True;UserID=sa;Password=sa;lnitialCatalog=aa;DataSource=192.168.1.1;(如是本地服务器则DataSource=.)数据库在192.168.1.1上,数据库名字是aa例程:strConnection="Provider=SQLOLEDB;DataSource=local;lnitialCatalog=DVDRentDB_Data.MDF;""UserID=sa;Password=820415";m_pConnection->Open((_bstr_t)strSQL,"","",adModeUnknown);或者是在此处不设置UserID和Password,而直接在Open的第2、3个参数中设置。strConnection="Provider=SQLOLEDB;DataSource=local;lnitialCatalog=DVDRentDB_Data.MDF";m_pConnection->Open((_bstr_t)strSQL,"sa","820415",adModeUnknown);注意:上面设置连接字符串的时候,如果过长需要分行时,则每一行都要加上双引号,在最后加上分号即可。如果是本地服务器,则DataSource=local或本地服务器名均可。若数据库没有设置密码,在连接字符串中可以将其省略,但UserID不能省若数据库和程序文件不在同一文件夹下,直接写数据库名即可,在InitialCatalog中不需加上该数据库的存储器地址。3.3)使用OLEDB提供者实现对远程SQLServer的标准安全连接串strConnect=_T("Provider=sqloledb;NetworkLibrary=DBMSSOCN;""DataSource=130.120.110.001,1433;""InitialCatalog=MyDateBaseName;""UserID=MyUserName;Password=MyPassword;");4)、使用m_pConnection的Open方法实现对数据库的连接在ADO的操作中建议使用try...catch()来捕获错误信息,因为它有时会经常出现一些意想不到的错误try{m_pConnection->Open((_bstr_t)strSQL,"","”,adModeUnknown);}catch(_com_errore)〃捕捉异常!\r\n错误信息:%s",e.ErrorMessage());〃显示错误信息m_pConnection的Close方法关闭连接即可m_pConnection=NULL;CStringstrError;strError.Format(”连接数据库发生异常AfxMessageBox(errormessage);}4、关闭连接一般重载App类的Exitlnstace()函数实现调用m_pConnection->Close();注意:由于初始化COM库调用的是AfxOleInit,这种方法初始化COM库的优点就在于资源的释放也是自动进行的,所以不必担心资源泄漏的问题。二、数据库操作ADO库中包含的三个基本接口为_ConnectionPtr接口、_CommandPtr接口、_RecordsetPtr接口。1、_ConnectionPtr接口该接口返回一个记录集或一个空指针。通常用它来创建一个数据库连接,或执行一条不返回任何结果的SQL语句,如一个存储过程。不推荐使用_ConnectionPtr接口返回一个记录集,对于要返回记录集的操作通常用_RecordsetPtr来实现,而且使用_ConnectionPtr时要想得到记录数目必须遍历所有记录,但使用_RecordsetPtr时则不需要。2、_CommandPtr接口该接口返回一个记录集。它提供了一种简单的方法来执行返回记录集的存储过程和SQL语句。在使用_CommandPtr接口时,可以利用全局_ConnectionPtr接口,也可以在_CommandPtr接口里直接使用连接串。如果只执行一次或者几次数据库访问操作,后者是比较好的选择。但是,如果频繁访问数据库,并要返回很多记录集,那么应该使用全局_ConnectionPtr接口创建一个数据库连接,然后使用_CommandPtr接口执行存储过程和SQL语句。3、_RecordsetPtr接口该接口是一个记录集对象。_CommandPtr接口_RecordsetPtr的Command对象一样与前两种对象相比,它对记录集提供了更多的控制功能,如记录锁定、游标控制等。同一样,它不一定要使用一个已经创建的数据库连接,可以用一个连接串代替连接指针赋给connection成员变量,让它自己创建数据库连接。如果使用多个记录集,最好的方法是同使用已经创建了数据连接的全局_ConnectionPtr接口,然后使用_RecordsetPtr执行存储过程和SQL语句。注意:可以使用Recordset对象来执行查询命令,但如果查询或者存储过程是需要参数的,这时就只能使用Command对象。使用Recordset对象操作数据库:假定已经成功使用Connection对象创建了数据源的连接,连接指针为m_pConnection。创建记录集声明记录集指针_RecordsetPtrm_pRecordset;仓U建记录集m_pRecordset.Createlnstance(__uuidof(Recordset));打开记录集记录集指针创建完毕后,调用该指针的Open方法打开记录集。该函数声明如下:HRESULTRecordset15::Open(const_variant_t&Source,const_variant_t&ActiveConnection.enumCursorTypeEnumCursorType,enumLockTypeEnumLockType,longOptions);各个参数的含义如下:参数Source:为_variant_t类型的引用,可以为有效的Command对象、SQL语句、表名、存储过程调用等。参数ActiveConnection:为_variant_t类型的引用,为已经建立好的连接。参数CursorType:用于设置在打开Recordset时提供者应使用的游标类型,它可取CursorTypeEnum中的任一值,默认值为adOpenForwardOnly。参数LockType:用于设置在打开Recordset时提供者应使用的锁定类型,它可取枚举LockTypeEnum中的任一值,默认值为adLockReadOnly。参数Options:用于设置获取Source(即Open第一个参数)的方式,其类型long。游标类型忤HL吊里描述adOpenStatic静态游标.直他用户所作的添加.更改或制除不可见adOpenVon\rardOnly仅向前游标.为默认值.大致可静念齡标相同。adOpenDyiuimie动态游标,其他用户的添加.更改威制除均可见adOpenKeyset键集游标,不能访问応他用户删除、添加的记录adOpcnLnspecified未描定游标类樂*•印说明adLoeLl.!nspecifled未指定adL.ockReadOnly只读记录集ddLockPcssimistii悲观锁述■数抑;史祈时锁定其它所冇动作adLock(Jptimistic乐观预定■仅在调用Updateh法时硕定记4aclLockBatchOptimistic乐观批更新’需要批更新模式支持Options収值卄£1.说叨adtnidIdd'W供ri应该将Sourcefl■'勺甜令的文生定义來计畀adCmdTable指示ADO也成SQL1*1制以便从任血i「氓中命名的表中遞阿所冇行ddCmdTdbleDinxt指小提供者更改从iiSource'l'命名的表屮返何所有行udCmdStorePiXK猎示提供者应该将Source视为存储过程adCindUnktiown指示Source参数中的命令类卑九未知(打开记录集函数)例程1:CStringstrSQL="select*frommytablename";m_pRecordset->Open(_variant_t(strSQL),m_pConnection.GetInterfacePtr(),adOpenDynamic,adLockOptimistic,adCmdText);使用SQL语句作为Open方法的第一个参数Source的值,此时Options为adCmdText例程2:m_pRecordset->Open(_variant_t("tbDVDInfo")),m_pConnection.GetInterfacePtr(),adOpenDynamic,adLockOptimistic,adCmdTable);直接使用表名作为第一个参数,此时Options应为adCmdTable遍历记录集一般在返回记录集时,通常要遍历结果记录集,以便查看或编辑某一条记录,Recoreset指针提供了几个用于实现遍历的方法。记录集遍历成协函数方法功能描述Move将记录集指竹移动到指定的记乘MovcFirst将记录集描针移动到第一条记录MoveLast将ki录集指针移动到堆后傑记录MoveNext将记录集指计移动到下一条记录1MovePrev将记录集抬针移动到前一条记录注意:为了避免发生异常,一般在使用MoveFirst、MovePrev之前,需要使用记录集的指针BOF属性来检测当前的记录集指针是否位于第一条记录之前;在使用MoveLast、MoveNext之前需要使用记录集指针的EOF属性来检测当前的记录集指针是否位于最后一条记录之后。记录集定位记录集接口类提供了两种定位方法:绝对定位和书签定位前者通过设置或者获取AbsolutePosition属性即可,其值从1开始,并且当前记录为记录集中第一条记录时等于1对于后者可以通过设置或获取BookMark属性即可访问记录集最简单的方法是直接使用如下语句:m_pRecordset->GetCollect(字段名);设置字段值:m_pRecordset->PutCollect(字段名,新值);两个方法的原型:_variant_tGetCollect(const_variant_t&Index)voidPutCollect(const_variant_t&Index,const_variant_t&pvar)其中:参数Index可以是字符串表示字段名,也可以是整型,表示字段对应的序号。pvar表示要写入的变量值。例如:_variant_tvar;var=m_pRentRecordset->GetCollect("ID");var=m_pRentRecordset->GetCollect(long(0));都可以记录集更新更新记录集包括添加新的记录、编辑当前记录和删除当前记录记录集接口指针对这三种操作分别提供了相应的方法添加新的记录:AddNew编辑当前记录:Edit删除当前记录:Delete注意:记录集接口指针针对AddNew以及Edit方法提供了Update方法,用于在数据库中更新新添加或者编辑后的记录。AddNew方法:用于添加新纪录(该添加是直接在表的末尾续加的),该方法可以使用参数,在参数中指定要添加的新纪录;也可以不使用参数,而在后面使用PutCollect方法,并需使用Update函数保存新纪录。Update方法:用于保存从调用AddNew方法以来所作的任何更改。//++++++++++++++++++++++++++++++++++++++++++〃在表的末尾增加新纪录m_pRecordset->AddNew();//++++++++++++++++++++++++++++++++++++++++++m_pRecordset->PutCollect("姓名",_variant_t(m_strName));m_pRecordset->PutCollect("工作单位",_variant_t(m_strComName));m_pRecordset->PutCollect("单位地址",_variant_t(m_strComAddr));〃更新数据库-将新纪录存入数据库m_pRecordset->Update();记录集关闭在对记录集的操作完成后,必须及时关闭记录集。if(m_pRecordset!=NULL){m_pRecordset->Close();m_pRecordset=NULL;}最近由于工作之需,要利用VC进行一些高级的数据库操作,如执行存储过程等。遍寻网络资源发现好使的不多(经常#30XX错误,大部分应该是COM的VARIANT数据类型所致,其实有个讨巧的方法,请看下文),在自己的实验下小有所得。记下学习笔记以备参考:1进行ADO编程的必备步骤:引入msado15.dll#import"c:\programfiles\commonfiles\system\ado\msado15.dll"no_namespacerename("EOF","adoEOF")〃避免与文件的结束符号混淆,将EOF改为adoEOF当然要记得在所有#include之后加入啊2也是必备的:初始化Com库::Colnitialize(NULL);///初始化COM库3建立数据库连接_ConnectionPtrm_pConnection;〃连接数据库的Com智能指针,可以自动ReleaseA_Am_pConnection.Createlnstance("ADODB.Connection");〃建立实例返回HRESULT所以最好if一下看看成功否4连接数据库m_pConnection->Open("Driver={SQLServer};Server=localhost;Database=Northwind;UID=sa;PWD=wxy","","",adModeUnknown);最好用Try的,可以捕获错误啊,例如try{m_pConnection->Open("Driver={SQLServer};Server=localhost;Database=Northwind;UID=sa;PWD=wxy","","",adModeUnknown);//其他数据库操作}catch(_com_errore){//处理错误吧}〃调用存储过程5创建执行存储过程的命令对象_CommandPtrm_pCommand;//还是智能指针m_pCommand.Createlnstance("ADODB.Command");//实例m_pCommand->ActiveConnection=m_pConnection;//设置连接,另U忘了啊m_pCommand->CommandText="Test";//存储过程为Test假设我的存储过程如下:CREATEPROCEDURETest@idint,@Namevarchar(20),@sdatedatetime,@retchar(1)outputASinsertintoVCStorprocvalues(@id,@Name,@sdate)if@@error=0set@ret=1elseset@ret=0go6建立传入存储过程的参数存储过程Test中输入参数id,name,sdate输出参数ret记住他们的类型和大小啊下面就来创建4个参数VC中用_ParameterPtr智能指针来建立参数,具体如下:_ParameterPtrm_pParam;m_pParam.Createlnstance("ADODB.Parameter");_ParameterPtrm_pParam1;//附加数字的命名习惯不好别学我啊m_pParam1.Createlnstance("ADODB.Parameter");_ParameterPtrm_pParam2;m_pParam2.Createlnstance("ADODB.Parameter");_ParameterPtrm_pParamRet;m_pParamRet.CreateInstance("ADODB.Parameter");别高兴还没有真正的建立好参数m_pParam=m_pCommand->CreateParameter("id",adlnteger,adParamlnput,-1,(_variant_t)"10");〃给参数设置各属性m_pCommand->Parameters->Append(m_pParam);〃加入到Command对象的参数集属性中m_pParam1=m_pCommand->CreateParameter("Name",adVarChar,adParamlnput,20,(_variant_t)"songwenfeng");m_pCommand->Parameters->Append(m_pParam1);m_pParam2=m_pCommand->CreateParameter("sdate",adVarChar,adParamlnput,32,(_variant_t)"2004-6-8");m_pCommand->Parameters->Append(m_pParam2);〃**************这里有个问题:就是DateTime数据类型要用adVarChar来传递,由于我们的时间格式为XXXX-XX-XXXX:XX:XX所以32位足够了,有时我们会用adDate或adDBDate类型来传递DateTime,这就是导致error#3015的原因之一,当然用它来传递应该是可以的,但是小弟至今没有成功过,哪位大虾知道告诉小弟一声啊*******〃〃添加存储过程输出参数m_pParamRet=m_pCommand->CreateParameter("ret",adChar,adParamOutput,1);m_pCommand->Parameters->Append(m_pParamRet);大功告成,执行吧引用m_pCommand->Execute(NULL,NULL,adCmdStoredProc);//***第一个参数是被影响的记录数是一个VARIANT的指针变量,需要的话设个变量取过来就是了但是MSDN说TheRecordsAffectedparameterappliesonlyforactionqueriesorstoredprocedures.RecordsAffecteddoesnotreturnthenumberofrecordsreturnedbyaresult-returningqueryorstoredprocedure.Toreturnthisinformation,usetheRecordCountproperty。就是说有返回值的存储过程是不会返回影响的记录数的,要使用RecordCount属性第二个参数是指向Parameters的VARIANT指针,是可选的,既然设置好了参数指针就把它设为NULL吧。MSDN说AVariantarrayofparametervaluespassedwithanSQLstatement.(Outputparameterswillnotreturncorrectvalueswhenpassedinthisargument.)用这个参数的话输出参数将不会返回正确的值。微软是不是挺有意思*************〃数据库里已经有了一条新记录了,看看idnamesdate10songwenfeng2004-6-87最后一步,关闭连接,释放Com,走人!!
本文档为【VC++与ADO对数据库的链接】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
该文档来自用户分享,如有侵权行为请发邮件ishare@vip.sina.com联系网站客服,我们会及时删除。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。
本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。
网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
下载需要: 免费 已有0 人下载
最新资料
资料动态
专题动态
is_072127
暂无简介~
格式:doc
大小:25KB
软件:Word
页数:8
分类:
上传时间:2019-09-18
浏览量:0