MFC 和 数据库Access 用 Ado类 操作

      

   短学期一直在做MFC,对于MFC和数据库Access的连接保存有一定的了解,于是记录下这篇有关MFC如何操作数据库。

     因为用MFC建立的对话框中的数据需要保存,所以一般有俩种选择,-是保存在文本中,调用MFC的基础类库中的CFile类;二是保存在数据库中,可通过调用自定义的Ado类;

      封装Ado类原因:把MFC需要调用数据库的操作整合成Ado类,在需要用到数据库操作时就可以直接调用Ado类,这样简单方便,尤其是频繁调用数据库时,不需要每次调用都用一大推代码。


    自定义的Ado类,可连接,打开,退出数据库和获取数据库记录集的指针,如果想要数据库的其他操作,也可以加入。

下面为Ado的类成员函数

BOOL CAdo::OnInitAdoConn()
{
HRESULT hr; //创建对象
try
{
hr = m_pConnection.CreateInstance("ADODB.Connection"); //创建Connection对象
if(SUCCEEDED(hr))
{
hr = m_pConnection->Open("Provider=Microsoft.ACE.OLEDB.12.0;\
Data Source=Dairy.accdb;","","",adModeUnknown); //连接数据库
AfxMessageBox("数据库连接成功");        /
}
}
catch(_com_error e)
{
CString errorMsg;
errorMsg.Format("连接数据库失败!\r\n错误信息:%s", e.ErrorMessage());
AfxMessageBox("errorMsg"); //显示错误信息
}
return TRUE;
}


//注意连接数据库时这行:Open("Provider=Microsoft.ACE.OLEDB.12.0;\   //版本信息  

Data Source=Dairy.accdb;","","",adModeUnknown);  Dairy是我在数据库的名字,accdb是access07,版本不同,后缀名也不同

// 打开数据库
_RecordsetPtr& CAdo::OpenRecordset(CString sql)
{
ASSERT(!sql.IsEmpty());


try
{
m_pRecordset.CreateInstance("ADODB.Recordset");

if(NULL == m_pRecordset)
{
AfxMessageBox("RecordSet 对象创建失败! 请确认是否初始化了COM环境");
}


//设置游标属性
m_pRecordset->CursorLocation = adUseClient;

//打开记录集
m_pRecordset->Open(_variant_t(sql), _variant_t((IDispatch *)m_pConnection, true), adOpenDynamic, adLockOptimistic, adCmdText);
}
catch(_com_error e)
{
CString errorMsg;
errorMsg.Format("连接数据库失败!\r\n错误信息:%s", e.ErrorMessage());
AfxMessageBox(errorMsg); //显示错误信息
}
return m_pRecordset;


}


写这个类时注意用try-catch,这样调试时如果是数据库这里的错误,会事半功倍找出bug


接下来就是MFC的程序与自定义的Ado类的连接准备工作

    先在stdafx.h的类定义下写这行代码

#import   "C:\Program Files\Common Files\System\ado\msado15.dll"\
no_namespace, rename ("EOF","adoEOF")               //避免EOF与MFC的冲突,重命名

   

   并在主对话框中的InitInstance函数下调用    AfxOleInit();    //一定不要定义在其他多次调用数据库的窗口函数中,它只可以被调用一次,如果被调用多次,会报错,执行调用数据库的操作只能正常进行一次;


    之后就每当MFC中的数据需要在数据库中进行改动时调用Ado类就好;

           先创建Ado类的一个实例,再按链接打开,获得记录集的指针对数据库进行操作,最后退出数据库。

         如

        CAdo ado;
ado.OnInitAdoConn();  //数据库连接
        _RecordsetPtr pRecordset=ado.GetReordset();
       pRecordset=ado.OpenRecordset("select * from Dairy");//打开数据库集  

   //获取记录集的指针,之后就可以用相应的函数对数据库中的数据进行操作

      pRecordset->MoveFirst();    

      pRecordset->GetCollect ("  ")

      pRecordset->PutCollect("","")

      pRecordset->Update();
      

等................

       ado.ExitConnection();

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

            pRecordset=ado.OpenRecordset("select * from Dairy");//打开数据库记录集时 执行一条SQL语句,从数据库表为Dairy中选择记录集。

                 提醒:定义数据库的表时一定不要用数据库的保留字,例如我把表的名字取为User,那"select * from User"会报错,不过报错时也可以慢慢调试到这里。



    

     最后再说有关数据库动态创建表的事情:刚开始我是要实现这样一件事,用户的记录的信息都会存在数据库中的表里,很自然的想到一个用户一个表,用户的资料用另一个数据库或表进行操作,这样用户记录的信息就会很清楚的排列,但没有设想动态创建数据库表的难度,在这个自定义的Ado类基础上肯定还得修改很多,至少得用cmd的sql语句了。

    但经老师提醒,因为数据库的每个表都可以存储很多数据,把每个用户记录的信息全存在一个表里,当然加一列用户资料的标志名放入每条信息中用来识别,此外把用户的资料放于另一个表中,这样就解决了不需要动态创建表的难题,只要创建一个用户资料表,一个用户记录信息表,更具有可操作性,当然动态创建表仍是可实现的。









你可能感兴趣的:(数据库,mfc,Access,ado类)