MFC数据库(封装好的类)

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

1.在StdAfx.h头文件中加入此句子#imp ort "c:\program files\common files\system\ado\msado15.dll"\

no_namespace rename("EOF","adoEOF")

2.在App类的InitInstance()函数中加入

::CoInitialize(NULL);//表示com库的初始化

鼠标右键点击App类名添加虚函数ExitInstance(),在其中加入代码::CoUninitialize();//释放com库。

3.获取连接字符串。

最简单的方法就是新建一个.txt文件,将其后缀名改为.udl,双击它,在“提供程序”标签页中选择“Microsoft OLE DB Provide fo Sql Server”,然后在“连接”标签页选择填写服务器、数据库、登陆方式等信息,最后按“确定”。连接完成之后,将其用写字板打开,第三行信息,如“Provider=SQLOLEDB.1;Integrated Security=SSPI;Persist Security Info=False;Initial Catalog=RuleDB_Da ta;Data Source=PYE”即为连接字符串。注意,若数据库位于本机,在选择填写服务器一栏可直接填写(local),记得一定要加括号。

4.连接数据库

在这里引入一个编写好的封装类:ADOConn。该类封装了连接数据库,对数据库进行添加、删除、修改操作及获取查询记录集操作的方法。用户可直接使用,这个类的头文件和cpp文件内容将在本文最后给出。

在一个工程里加入该类的方法为:把该类的头文件和cpp文件拷

贝到工程所在的文件夹里。然后在工程的工作区选择Project->Add to Project->Files,将这两个文件选择加入。

之后,就可以在程序里应用这个类了。

首先在要用到数据库的类的头文件里设一个该类的对象,即加入代码:ADOConn m_Ado;注意:记得要先在最前面加入#include "ADOConn.h"。

在应用这个对象对数据库进行操作之前,先对其初始化:m_Ado.On InitADOConn(strConnect);其中strConnect即为上面获取的连接字符串。

若要获取数据库中的部分记录集,用m_Ado.GetRecordSet(strSql);其中strSql中存放查询语句,查询结果存放于m_Ado.m_pRecordset 中,然后可用GetCollect()函数挨个获取所有符合条件的记录的各个字段的值。用完后记得用m_Ado.m_pRecordset.Close()关闭记录集。添加、修改、删除操作,均用m_Ado.ExecuteSQL(strSql);语句完成。

此外,若同时需要多种记录集,则还需在要用到数据库的类的头文件里添加记录集的对象,即_RecordsetPtr m_pRecordset;m_pRecordset在用之前也需初始化,初始化语句为:m_pRecordset.CreateInstance(__uuidof(Recordset));,同样的,每回记录集用完之后也得用Close()函数关闭。

5.若在数据库应用程序编译时遇到102个错误,则可把Debug文件夹删了重新编译即可。

ADOConn类的头文件:

#if !defined(AFX_ADOCONN_H__2B491720_FA04_4800_B616_219E 55ABEA46__INCLUDED_)

#define

AFX_ADOCONN_H__2B491720_FA04_4800_B616_219E55ABEA46_ _INCLUDED_

#if _MSC_VER > 1000

#pragma on ce

#endif // _MSC_VER > 1000

class ADOConn : public CObject

{

public:

//添加一个指向Connection对象的指针:

_ConnectionPtr m_pConnection;

//添加一个指向Recordset对象的指针:

_RecordsetPtr m_pRecordset;

char error[1024];

public:

_ConnectionPtr& GetConnPtr() {return m_pConnection;}

_RecordsetPtr& GetRecoPtr() {return m_pRecordset;}

public:

//事务回滚

BOOL RollbackTrans();

//递交事务

BOOL CommitTrans();

//事务开始

BOOL BeginTrans();

BOOL adoBOF();//头

BOOL adoEOF();//尾

BOOL MoveNext();//下一个

BOOL CloseTable();//关闭表

BOOL CloseADOConnection();//关闭连接

BOOL GetCollect(LPCTSTR Name,CString &lpDest);//获取某个字段的值

//执行SQL语句包含update delete insert

BOOL ExecuteSQL(LPCTSTR lpszSQL);

//初始化连接数据库

BOOL On InitADOConn(LPCTSTR ConnStr);

//执行select语句获取记录集

_RecordsetPtr& GetRecordSet(LPCTSTR lpszSQL);

ADOConn();

virtual ~ADOConn();

};

#endif

// !defined(AFX_ADOCONN_H__2B491720_FA04_4800_B616_219E5

相关文档
最新文档