VC6.0数据库编程之MFC ODBC

                                                                                    VC6.0数据库编程之MFC ODBC
      在vc中,使用ODBC连接是数据库有两种方法,第一种就是使用ODBC API,第二种就是使用MFC ODBC,在这里我只谈一下MFC

ODBC。
      为了使数据库开发变得更方便,Microsoft对ODBC API进行的封装,使得我们开发数据库时可以直接使用MFC ODBC类:
    CDatabase:建立与数据源的连接
    CRecordset:获取记录集
    CRecordView:提供一个表单视图与某个记录集直接相连,利用对话框数据交换机制(DDX)在记录集与表单视图的空间之间传输数据
    CFieldExchange:支持记录字段数据交换(DFX),即记录集字段数据成员与相应的数据库的表的字段之间的数据交换
    CDBException:ODBC的异常类
   一、 在实际开发中,使用MFC ODBC类访问数据库步骤如下:
   a . 使用CDatabase类方法打开数据源:
      定义CDatabase对象m_db;调用其OpenEx方法打开数据源,OpenEx原型如下:
      virtual BOOL OpenEx( LPCTSTR lpszConnectString, DWORD dwOptions=0 );
      参数一为连接字串:如"DNS=memo;UID=sa;PWD=123",DNS为数据源名称,注意到如果为lpszConnectString传递NULL,则将  

出现数据源对话框,提示用户选择一个数据源。
      参数二为打开方式,缺省值0表示以共享方式打开数据库,带有写访问,不装入ODBC游标库DLL,并且只有在没有足够信息形  

成连接时显示ODBC连接对话框。可选参数如下:
 CDatabase::openExclusive:此类库版本不支持。为共享数据源总是打开的。如果选定此选项,断言失败。
 CDatabase::openReadOnly:以只读方式打开
 CDatabase::UseCursorLib   装入ODBC游标库DLL。游标掩盖了基础ODBC驱动程序的一些功能,有效地阻止使用动态集(如果

驱动程序支持它们)。如果装入游标库,支持的唯一游标是静态快照和只能向前游标。缺省值为TRUE。如果计划从CRecordset直接创建

一个记录集对象而不派生,则不应装入游标库。
 CDatabase::noOdbcDialog:不管是否提供了足够的连接信息,不显示ODBC连接对话框。
 CDatabase::forceOdbcDialog:总是显示ODBC连接对话框。
            如果要使用信任连接,即不需要用户名和密码,则应该使用Open方法,但在打开记录集时有限制,见后。
     (注:创建数据源方法:控制面板—>管理工具—>数据源(ODBC)—>添加,选择对应的驱动程序,如数据库在SQL Server下则选择

SQL Server—>完成输入数据名称,描述,选择服务器"(local)",下一步,选择用户输入登陆ID和密码的SQL Server验证,输入登陆ID和

密码,下一步,勾选更改默认数据库,下一步,完成,测试。)
   b . 定义CRecordset对象,调用其Open方法打开记录集,如
       CRecordset rs(&m_db);
       virtual BOOL Open( UINT nOpenType = AFX_DB_USE_DEFAULT_TYPE, LPCTSTR lpszSQL = NULL, DWORD dwOptions = none

);
       参数一为打开类型,如下:
 AFX_DB_USE_DEFAULT_TYPE:默认值
 CRecordset::dynaset:动态记录集,支持双向游标,并保持同所连接的数据源同步,对数据的更新操作可以通过一个fetch操

作获取。
 CRecordset::snapshot:静态快照,一旦形成记录集,此后数据源的所有改变都不能体现在记录集里,应用程序必须重新进行

查询,才能获取对数据的更新。该类型记录集也支持双向游标。
 CRecordset::dynamic:同CRecordset::dynaset记录集相比,CRecordset::dynamic记录还能在fetch操作里同步其它用户对数据

的重新排序,大部分ODBC驱动程序不支持这种记录集
 CRecordset::forwardOnly:除了不支持逆向游标外,其它特征同CRecordset::snapshot相同。
       参数二为sql查询语句,查询结果保存在记录集中
       参数三指定创建记录集时的常用选项
 CRecordset::none:无选项(缺省),与其它所有选项互斥,可以更新、删除、添加记录
  CRecordset::appendOnly:不允许修改和删除记录,但可以添加记录.
  CRecordset::readOnly:记录集是只读的.
 其它选项查看MSDN
       使用信任连接时,如果使用CRecordset::dynaset会出现ODBC不支持动态记录集错误出现CRecordset::dynamic打开记录集,会出现

ODBC不支持动态指针错误,而用CRecordset::forwardOnly则出现无效的游标位置错误
   c . 绑定记录集(通过RFX)
       通过向导插入CMySet类且以CRecordset为基类时,会自动生成与表字段对应的变量,并在CMySet的DoFieldExchange中自动与表

字段绑定,如:RFX_Long(pFX,_T("[列名]"),变量名);pFX为CFieldExchange类指针。(注意字段类型)
       绑定之后,就可以使用这些变量更新对应字段,如添加,先调用AddNew,然后调用SetFieldNull($变量名,FALSE)将该字段标记

为脏数据(changed),最后给变量赋值,调用Update将新记录保存到数据库,Requery刷新记录集并将记录集指针回到第一条记录处,完成

插入。在AddNew和Edit后必须Update完成操作。调用Edit后可以修改当前记录。
   d . 参数化记录集和查询
       CRecordset成员变量:m_strFilter负责对记录集进行过滤,它存放着sql语句中where子句的条件字符串,通过
m_strfilter="列名='值'"方式赋值,赋值后调用该对象打开或刷新的记录集已经过滤,并且参数二只需给出表名rs.Open

(CRecordset::snapshot,"book")。m_strSort对记录集进行排序,m_strSort="列名".如果在Open的lpszSQL参数中已包括了WHERE和

ORDER BY子句,那么m_strFilter和m_strSort必需为空.
       除直接赋值外,还可以使用参数化:
         (1) 声明参变量,代码如下:
 CString strName;
  int nAge;
         (2) 在构造函数中初始化参变量如下:
  strName =_T("");
  nAge =0;
 m_nParams=2;
         (3) 将参变量与对应列绑定,代码如下:
 pFX->SetFieldType(CFieldExchange::param)
 RFX_Text(pFX,_T("Name"), strName);
 RFX_Single(pFX,_T("Age"), nAge);
         完成以上步骤之后就可以利用参变量进行条件查询了,代码如下:
 m_pmyRS->m_strFilter="Name=? AND age=?";
 m_ pmyRS -> strName ="feng";
 m_ pmyRS ->nAge=20;
 m_ pmyRS ->Open();//如果记录集已经打开,则刷新
参变量的值按绑定的顺序替换查询字串中的“?”通配符。
   f . 书签定位:在当前记录处设置书签,经过一系列移动后再查找该书签处记录,可直接返回书签位置
 CDBvarint bookmark;
 rs.GetBookmark(bookmark);//获取当前记录保存到书签中
 rs.SetBookmark(bookmark);//返回书签位置
        使用书签前可通过CRecordset::CanBookmark确定是否支持书签定位,如果是,还需要在记录集的Open函数的dwOptions中加上
CRecordset::useBookmark,在调用之前调用CDatabase::GetBookmarkPersistence来核对是否可以安全调用SetBookmark
        绝对定位: row=10;
           rs.SetAbsoutePosition(row);
        只向前滚动的记录集不支持定位。
   注:如果不涉及从数据库中获取记录,就不需要打开记录集,在数据源打开后,直接调用CDatabase::ExecuteSQL执行sql语句,如插

入、删除、更新等。只有在需要从数据库中获取记录时才打开记录集,用while( ! rs.IsEOF( ))判断是否超出记录集最后一条记录,如果

没有绑定记录集,可用GetFieldValue取当前记录的字段值,用MoveNext移到下一条记录。绑定记录集后,变量的值就是数据库中对应的

字段的值,可以直接对变量进行操作,不需要再用GetFieldValue获取。对于数据库中的数据类型与c++数据类型的转换,我将另外讨论


   二、事务处理
        首先调用CDatabase::BeginTrans( )开始事务,CommitTrans提交事务,Rollback回退,撤销操作
   三、异常处理:在数据库编程时,一般会出现的异常可用以下语句捕获
 TRY
 {......
 }
 CATCH(CDBException,ex)
 {
  AfxMessageBox (ex->m_strError);
  AfxMessageBox (ex->m_strStateNativeOrigin);  
 }
 AND_CATCH(CMemoryException,pEx)
 { 
  pEx->ReportError();
  AfxMessageBox ("memory exception");
 }
 AND_CATCH(CException,e)
 {
  TCHAR szError[100];
  e->GetErrorMessage(szError,100);
  AfxMessageBox (szError);
 }
 END_CATCH
    由于本人水平有限,如果有什么问题,希望大家指正,谢谢!    
再有一点,创建工程后,需要自己添加afxdb.h头文件,应为ODBC类定义在此文件中...

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
编 者 的 话 5 第1篇 基础篇 6 第1章 数据库原理与访问 7 1.1 数据库基本原理 7 1.1.1 概述 7 1.1.2 桌面数据库 7 1.1.3 对象数据库 8 1.1.4 关系数据库服务器 9 1.1.5 选择适用的数据库 9 1.2 数据库访问技术 10 1.2.1 概述 10 1.2.2 ODBC API 10 1.2.3 ODBCMFC类 11 1.2.4 DAO与RDO 11 1.2.5 OLE DB与ADO 12 1.3 数据库操纵语言SQL 13 1.3.1 SQL命令 13 1.3.2 SQL从句 13 1.3.3 SQL运算符 14 1.3.4 SQL合计函数 14 1.4 小 结 14 第2章 COM与数据库访问 15 2.1 COM的基本原理 15 2.1.1 COM历史 16 2.1.2 COM结构 16 2.1.3 COM优势 17 2.1.4 COM接口 18 2.1.5 COM与数据库访问 19 2.1.6 COM与Internet 19 2.2 ACTIVEX的数据库访问 19 2.2.1 ActiveX简介 19 2.2.2 ActiveX对数据库访问的支持 20 2.3 ATL的数据库访问 20 2.3.1 ATL目标 20 2.3.2 ATL内容简介 22 2.3.3 ATL对数据库访问的支持 22 2.4 小 结 23 第3章 数据库开发过程 23 3.1 阶段1:调查与分析 24 3.2 阶段2:数据建模 24 3.3 阶段3:功能设计 24 3.4 阶段4:选择数据库系统 25 3.5 阶段5:选择数据库访问技术 25 3.6 阶段6:代码设计 25 3.7 阶段7:测试与调试 26 3.8 阶段8:发行产品 26 第4章 VC++数据库开发基础 26 4.1 VC++ 6.0工程创建向导 26 4.2 VC++ 6.0数据库新建工具 27 4.3 VC++ 6.0的数据库工程 29 4.4 小 结 31 第2篇 实例篇 32 第5章 ODBC API编程 33 5.1 了解ODBC API 34 5.2 ODBC API编程步骤 34 5.2.1 步骤1:连接数据源 34 5.2.2 步骤2:分配语句句柄 36 5.2.3 步骤3:准备并执行SQL语句 36 5.2.4 步骤4:获取结果集 37 5.2.5 步骤5:提交事务 38 5.2.6 步骤6:断开数据源连接并释放环境句柄 39 5.3 ODBC API编程实例 39 5.3.1 实例概述 39 5.3.2 实例实现过程 40 5.3.3 编译并运行ODBCDemo1工程 97 5.3.4 ODBCDemo1实例小结 98 5.4 本 章 小 结 99 第6章 MFC ODBC编程 100 6.1 了解MFC ODBC 100 6.1.1 CDatabase类 100 6.1.2 CRecordSet类 100 6.2 MFC ODBC数据库访问技术 101 6.2.1 记录查询 101 6.2.2 记录添加 102 6.2.3 记录删除 102 6.2.4 记录修改 102 6.2.5 撤销数据库更新操作 103 6.2.6 直接执行SQL语句 103 6.2.7 MFC ODBC数据库操作过程 103 6.3 MFC ODBC编程实例 104 6.3.1 实例概述 104 6.3.2 实例实现过程 105 6.3.3 编译并运行ODBCDemo2工程 132 6.3.4 ODBCDemo2实例小结 137 6.4 本 章 小 结 137 第7章 DAO数据库编程 138 7.1 DAO的数据访问 138 7.1.1 DAO对象 138 7.1.2 MFC对DAO的支持 139 7.1.3 DAO与ODBC的比较 139 7.1.4 MFC的DAO类简介 139 7.2 DAO编程实例 142 7.2.1 实例概述 142 7.2.2 实例实现过程 143 7.2.3 运行DAODemo工程 167 7.2.4 DAODemo实例小结 171 7.3 小 结 172 第8章 OLE DB客户数据库编程 172 8.1 OLE DB原理 172 8.1.1 OLE DB与ODBC 172 8.1.2 OLE DB的结构 173 8.1.3 OLE DB的优越性 173 8.1.4 OLE DB对象 174 8.1.5 OLE DB客户模板结构 177 8.1.6 OLE DB客户模

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值