MFC使用ADO进行ACCESS数据库编程

2011-04-18 23:20:13|?次阅读|上传:huigezrx【已有?条评论】发表评论

关键词:C/C++, 数据库, ACCESS|来源:唯设编程网

【3】创建Connection对象并连接数据库

首先我们需要添加一个指向Connection对象的指针:

_ConnectionPtr m_pConnection;

下面的代码演示了如何创建Connection对象实例及如何连接数据库并进行异常捕捉。

BOOL CADOTest1Dlg::OnInitDialog() {
    CDialog::OnInitDialog();
    HRESULT hr;
    try {
        hr = m_pConnection.CreateInstance("ADODB.Connection");///创建Connection对象
        if(SUCCEEDED(hr))
        {
            hr = m_pConnection->Open("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=test.mdb",""
                ,"",adModeUnknown);
            /*连接数据库 
            上面一句中连接字串中的Provider是针对ACCESS2000环境的,对于ACCESS97,
            需要改为:Provider=Microsoft.Jet.OLEDB.3.51;            
            ACCESS2007需要修改连接的字符串
            标准安全策略
            Provider=Microsoft.ACE.OLEDB.12.0;
            Data Source=C:myFoldermyAccess2007file.accdb;Persist Security Info=False;
            使用了密码的数据库
            如果您的Access 2007数据库设置了密码,您需要特别的在连接字符串中指定它。           
            Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:myFoldermyAccess2007file.accdb;
            Jet OLEDB:Database Password=MyDbPassword;*/
        }
    }
    catch(_com_error e)///捕捉异常
    {
        CString errormessage;
        errormessage.Format("连接数据库失败!
错误信息:%s",e.ErrorMessage());
        AfxMessageBox(errormessage);///显示错误信息 
    }
}

 在这段代码中我们是通过Connection对象的Open方法来进行连接数据库的,下面是该方法的原型

HRESULT Connection15::Open(_bstr_t ConnectionString, _bstr_t UserID, _bstr_t Password, long Options )

ConnectionString为连接字串,UserID是用户名, Password是登陆密码,Options是连接选项,用于指定Connection对象对数据的更新许可权,

Options可以是如下几个常量:

adModeUnknown:缺省。当前的许可权未设置

adModeRead:只读

adModeWrite:只写

adModeReadWrite:可以读写

adModeShareDenyRead:阻止其它Connection对象以读权限打开连接

adModeShareDenyWrite:阻止其它Connection对象以写权限打开连接

adModeShareExclusive:阻止其它Connection对象打开连接

adModeShareDenyNone:允许其它程序或对象以任何权限建立连接

我们给出一些常用的连接方式供大家参考:

(1)通过JET数据库引擎对ACCESS2000数据库的连接

m_pConnection->Open("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:	est.mdb","","",adModeUnknown);

(2)通过DSN数据源对任何支持ODBC的数据库进行连接:

m_pConnection->Open("Data Source=adotest;UID=sa;PWD=;","","",adModeUnknown);

(3)不通过DSN对SQL SERVER数据库进行连接:

m_pConnection->Open("driver={SQLServer};Server=127.0.0.1;DATABASE=vckbase;UID=sa;PWD=139","","",adModeUnknown);

其中Server是SQL服务器的名称,DATABASE是库的名称

Connection对象除Open方法外还有许多方法,我们先介绍Connection对象中两个有用的属性ConnectionTimeOut与State

ConnectionTimeOut用来设置连接的超时时间,需要在Open之前调用,例如:

m_pConnection->ConnectionTimeout = 5;///设置超时时间为5秒
m_pConnection->Open("Data Source=adotest;","","",adModeUnknown);

State属性指明当前Connection对象的状态,0表示关闭,1表示已经打开,我们可以通过读取这个属性来作相应的处理,例如:

if(m_pConnection->State) m_pConnection->Close(); ///如果已经打开了连接则关闭它
发表评论0条 】
网友评论(共?条评论)..
MFC使用ADO进行ACCESS数据库编程