MFC数据库(封装好的类)
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 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