VC中利用ADO共同实现数据库的操作.docx

上传人:b****6 文档编号:8880389 上传时间:2023-02-02 格式:DOCX 页数:6 大小:16.67KB
下载 相关 举报
VC中利用ADO共同实现数据库的操作.docx_第1页
第1页 / 共6页
VC中利用ADO共同实现数据库的操作.docx_第2页
第2页 / 共6页
VC中利用ADO共同实现数据库的操作.docx_第3页
第3页 / 共6页
VC中利用ADO共同实现数据库的操作.docx_第4页
第4页 / 共6页
VC中利用ADO共同实现数据库的操作.docx_第5页
第5页 / 共6页
点击查看更多>>
下载资源
资源描述

VC中利用ADO共同实现数据库的操作.docx

《VC中利用ADO共同实现数据库的操作.docx》由会员分享,可在线阅读,更多相关《VC中利用ADO共同实现数据库的操作.docx(6页珍藏版)》请在冰豆网上搜索。

VC中利用ADO共同实现数据库的操作.docx

VC中利用ADO共同实现数据库的操作

VC中利用ADO共同实现数据库的操作

  ADO是应用层的编程接口,它通过OLEDB提供的COM接口访问数据,它适合于各种客户机/服务器应用系统和基于Web的应用,尤其在一些脚本语言中访问数据库操作是ADO的主要优势。

ADO是一套用自动化技术建立起来的对象层次结构,它比其他的一些对象模型如DAO(DataAccessObject)、RDO(RemoteDataObject)等具有更好的灵活性,使用更为方便,并且访问数据的效率更高。

SQL是强大的数据库操作系统,通过ADO和SQL语句的配合,我们可以的实现对数据库的一系列操作,例如创建数据库、创建表、创建索引,实现数据库的多重查询、高级查询和数据的汇总等技术。

下面通过例程介绍如何通过ADO和SQL语句的配合实现对数据库的操作。

  第一步:

通过Access创建数据库test.mdb。

  第二步:

创建单文档工程testado,所有的选项都取默认值。

  第三步:

COM库的初始化

  我们可以使用AfxOleInit()来初始化COM库,这项工作通常在CWinApp:

:

InitInstance()的重载函数中完成,请看如下代码:

  BOOLCADOTest1App:

:

InitInstance()

   {

    AfxOleInit();

    ......

  第四步:

用#import指令引入ADO类型库

  我们在stdafx.h中加入如下语句:

  #import"c:

\programfiles\commonfiles\system\ado\msado15.dll"no_namespacerename("EOF","adoEOF")

这一语句有何作用呢?

其最终作用同我们熟悉的#include类似,编译的时候系统会为我们生成msado15.tlh,ado15.tli两个C++头文件来定义ADO库。

  第五步:

在testadoview.h中定义一个指向Connection对象的指针:

_ConnectionPtrm_pConnection;

  第六步:

添加如下代码:

voidCTestadoView:

:

OnInitialUpdate()

{

CView:

:

OnInitialUpdate();

HRESULThr;

try

{

hr=m_pConnection.CreateInstance("ADODB.Connection");//创建Connection对象

if(SUCCEEDED(hr))

{

hr=m_pConnection->Open("Provider=Microsoft.Jet.OLEDB.4.0;DataSource=test.mdb","","",adModeUnknown);///连接数据库

///上面一句中连接字串中的Provider是针对ACCESS2000环境的,对于ACCESS97,需要改为:

Provider=Microsoft.Jet.OLEDB.3.51;}

}

}

catch(_com_errore)///捕捉异常

{

CStringerrormessage;

errormessage.Format("连接数据库失败!

\r\n错误信息:

%s",e.ErrorMessage());

AfxMessageBox(errormessage);///显示错误信息

}

}

  第七步:

在析构函数中关闭Connection对象并将其释放,代码如下:

CTestadoView:

:

~CTestadoView()

{

m_pConnection->Close();

m_pConnection.Release();

}

  第八步:

添加菜单项"创建数据库表",并添加相应的消息处理函数,然后添加代码如下:

voidCTestadoView:

:

OnAddtable()

{

_variant_tRecordsAffected;

m_pConnection->Execute("CREATETABLEnew(IDINTEGER,usernameTEXT,oldINTEGER)",&RecordsAffected,adCmdText);

}

  运行程序,执行菜单当中的命令"添加表",我们可以发现数据库中已经添加了一个表new,其中的字段有我们定义的字段。

  第九步:

添加菜单项"删除数据库表",并添加相应的消息处理函数,然后添加代码如下:

voidCTestadoView:

:

OnDeleteTable()

{

_variant_tRecordsAffected;

m_pConnection->Execute("DROPTABLEnew",&RecordsAffected,adCmdText);

}

  运行程序,执行菜单当中的命令"删除表",我们可以发现数据库中刚才添加的表new已被删除。

  第十步:

添加菜单项"添加一列",并添加相应的消息处理函数,然后添加代码如下:

voidCTestadoView:

:

OnAddColumn()

{

_variant_tRecordsAffected;

m_pConnection->Execute("ALTERTABLEnewADDnewcolumn1INTEGER",&RecordsAffected,adCmdText);

}

  运行程序,执行菜单当中的命令"添加一列",我们可以发现数据库中刚才添加的表new中已添加了一个新列。

  第十一步:

添加菜单项"删除一列",并添加相应的消息处理函数,然后添加代码如下:

voidCTestadoView:

:

OnAddColumn()

{

_variant_tRecordsAffected;

m_pConnection->Execute("ALTERTABLEnewADDnewcolumn1INTEGER",&RecordsAffected,adCmdText);

}

  运行程序,执行菜单当中的命令"删除一列",我们可以发现数据库中刚才添加的表new中的新列已被删除。

  第十二步:

添加菜单项"添加记录",并添加相应的消息处理函数,然后添加代码如下:

voidCTestadoView:

:

OnAddRecord()

{

_variant_tRecordsAffected;

for(inti=1;i<10;i++)

{

CStringstrSQL;

strSQL.Format("INSERTINTOnew(ID,username,old)VALUES(%d,'Washington',%d)",i,i*9);

m_pConnection->Execute((_bstr_t)strSQL,&RecordsAffected,adCmdText);

}

  运行程序,执行菜单当中的命令"添加记录",我们可以发现数据库中刚才添加的表new中添加了九条新的记录。

  第十三步:

添加菜单项"old字段加1",并添加相应的消息处理函数,然后添加代码如下:

voidCTestadoView:

:

OnOldAddone()

{

_variant_tRecordsAffected;

m_pConnection->Execute("UPDATEnewSETold=old+1",&RecordsAffected,adCmdText);

}}

  运行程序,执行菜单当中的命令"old记录加1",我们可以发现数据库中刚才添加的表new中的九条新的记录的old字段都自动加1。

  第十四步:

添加菜单项"统计记录数目",并添加相应的消息处理函数,然后添加代码如下:

voidCTestadoView:

:

OnTotalRecords()

{

_RecordsetPtrm_pRecordset;

_variant_tRecordsAffected;

m_pRecordset=m_pConnection->Execute("SELECTCOUNT(*)FROMnewwhereID>0",&RecordsAffected,adCmdText);

_variant_tvIndex=(long)0;

_variant_tvCount=m_pRecordset->GetCollect(vIndex);

///取得第一个字段的值放入vCount变量

m_pRecordset->Close();///关闭记录集

CStringMessage;

Message.Format("共有%d条记录",vCount.lVal);

AfxMessageBox(Message);///显示当前记录条数

}

  运行程序,执行菜单当中的命令"统计记录数目",我们可以得到数据库中记录的数目。

  第十五步:

添加菜单项"设置ID为索引",并添加相应的消息处理函数,然后添加代码如下:

voidCTestadoView:

:

OnSetIdIndex()

{

_variant_tRecordsAffected;

m_pConnection->Execute("CREATEUNIQUEINDEXidONnew(ID)",&RecordsAffected,adCmdText);

}

  运行程序,执行菜单当中的命令"设置ID为索引",我们可以发现数据库中ID被设置为索引。

  第十六步:

添加菜单项"数据汇总"、"old字段的总和"、"old字段的均值"、"old的最小值"、"old字段的最大值",并添加相应的消息处理函数,然后添加代码如下:

voidCTestadoView:

:

OnOldMax()

{

_RecordsetPtrm_pRecordset;

_variant_tRecordsAffected;

m_pRecordset=m_pConnection->Execute("selectMAX(old)fromnew",&RecordsAffected,adCmdText);

_variant_tvIndex=(long)0;

_variant_tvCount=m_pRecordset->GetCollect(vIndex);

///取得第一个字段的值放入vCount变量

m_pRecordset->Close();///关闭记录集

m_pRecordset.Release();

CStringMessage;

Message.Format("最大值是%d",vCount.lVal);

AfxMessageBox(Message);

}

voidCTestadoView:

:

OnOldMin()

{

_RecordsetPtrm_pRecordset;

_variant_tRecordsAffected;

m_pRecordset=m_pConnection->Execute("selectMIN(old)fromnew",&RecordsAffected,adCmdText);

_variant_tvIndex=(long)0;

_variant_tvCount=m_pRecordset->GetCollect(vIndex);

///取得第一个字段的值放入vCount变量

m_pRecordset->Close();///关闭记录集

m_pRecordset.Release();

CStringMessage;

Message.Format("最小值是%d",vCount.lVal);

AfxMessageBox(Message);

}

voidCTestadoView:

:

OnOldTotal()

{

_RecordsetPtrm_pRecordset;

_variant_tRecordsAffected;

m_pRecordset=m_pConnection->Execute("selectSUM(old)fromnew",&RecordsAffected,adCmdText);

_variant_tvIndex=(long)0;

_variant_tvCount=m_pRecordset->GetCollect(vIndex);

///取得第一个字段的值放入vCount变量

m_pRecordset->Close();///关闭记录集

m_pRecordset.Release();

CStringMessage;

Message.Format("总和是%d",(long)vCount);

AfxMessageBox(Message);

}

voidCTestadoView:

:

OnOldAverage()

{

_RecordsetPtrm_pRecordset;

_variant_tRecordsAffected;

m_pRecordset=m_pConnection->Execute("selectAVG(old)fromnew",&RecordsAffected,adCmdText);

_variant_tvIndex=(long)0;

_variant_tvCount=m_pRecordset->GetCollect(vIndex);

///取得第一个字段的值放入vCount变量

m_pRecordset->Close();///关闭记录集

m_pRecordset.Release();

CStringMessage;

Message.Format("平均值是%d",(long)vCount);

AfxMessageBox(Message);

}}

  运行程序,执行菜单当中的汇总命令,我们可以得到相关的汇总信息。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 高等教育 > 农学

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1