- 1、本文档共11页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第七章 数据库编程
VC++能够将各种关系型数据库管理系统(DBMS)与面向对象的编程方法有机地结合,使得数据库的处理和应用程序的开发都能很好地进行。它为用户提供了3种基本的数据库方式,即:ODBC、DAO和OLE DB。
本章仅介绍MFC的ODBC编程方法与技巧。
第一讲 数据库概述
一、几个重要概念
数据库――指以一定的组织形式存放于计算机内的相关数据的集合。
DBMS――数据库管理系统,是一种能对数据库进行各种操作和有效管理的软件系统,常见的如:Microsoft Access、Microsoft SQL Server、Sybase SQL Server、Microsoft Visual Foxpro等等。
SQL――结构化查询语言,为大多数数据库管理系统实现复合管理提供了一个公用的接口。其语句有两种类型:一种称为“数据定义语句(DDL)”,可用于创建表和索引等;另一类为“数据操作语句(DML)”,用于读取数据、更新数据和执行其它常规操作。
ODBC――Open Database Connectivity,开放数据库连接。是VC++提供的应用程序设计接口(API)方式之一,它可使得任何一个数据库都可以通过ODBC驱动器与指定的DBMS相关联。用户的程序可以通过调用ODBC驱动管理器中的相应驱动程序达到管理数据库的目的。
除此之外,VC提供的其余两种接口方式(DAO、OLE DB)请参阅P204页7.2节上面的有关内容。
二、ODBC数据库管理
ODBC是一种基于SQL语言的程序设计接口,它大大简化了Windows应用程序与DBMS的连接,同时,通过MFC类库所提供的3个数据库类――CDatabase、CRecordSet、CRecordView,使得通过Windows应用程序管理海量数据库变得更方便和容易。
例子:设计一个基于数据库支持的SDI/MDI应用程序框架。
一般步骤:
用自己熟悉的DBMS创建一个数据库;
自定义ODBC数据源名(DSN)
在“控制面板”中双击“ODBC数据源”图标打开数据源管理器;
单击“添加”按钮,弹出“创建DSN”对话框;
选择好用户拟添加的DSN驱动程序,如“Microsoft Access Driver”,单击“完成”;
在新弹出的“ODBC数据源安装”对话框内,键入“数据源名”和“描述”项,单击“选取”钮,选好刚创建好的“DSN”;
依次“确定”、“确定”,退出对话框,结束设置。
使用应用程序向导创建一个“基于数据库支持”的SDI或MDI(注意:在向导的第2步设置中必须选择“无文件支持的数据库视图”或“有文件支持的数据库视图”);同时,单击“数据源”按钮,进入下层对话框。
在ODBC下拉列表中选取以前创建的“DSN”,单击“确定”,进入下层;
在“选择数据库表名称”对话框中,选取指定“表名”,单击“确定”;
单击“完成”,返回第2步;
向导的其它步骤缺省,编译运行。完成程序框架的创建。
创建“浏览数据库记录”的对话框。
通过以上步骤,MFC自动为用户创建了浏览数据库记录的工具按钮和“记录”主菜单项,但要想在视图中看到数据库的记录,则需要进一步添加对话框控件,使之与数据表的字段相关联。操作如下:
切换到“ResourceView”标签页,定位并打开表单视图类的对话框资源IDD_EX_ODBC_FORM;
为对话框添加相关控件(如:P209上图表);
打开“类向导”对话框,切换到“成员函数”标签页,选择“用户视图类”,一一为以上“控件”添加相关联的数据成员;(注意:这里的数据变量已经自动被设置好了,用户只需要从下拉列表中选择即可);
编译并运行,即可在视图中实现数据库表的浏览。
第二讲 数据库编程
包含“显示记录总数、当前记录号”、“编辑记录”、“处理多个库表”三个部分。
1、显示记录总数、当前记录号
从前面所创建的程序中,可发现用户虽然可以通过视图对话框实现数据库表的记录浏览,但状态行并未能显示出“当前库表有多少条记录”以及“当前记录的索引号”等信息,这一功能的实现,可通过分别访问CRecordset类的两个成员函数GetRecordCount和GetStatus来达到。
下面的步骤,就是要实现在状态栏中显示上述信息。
打开MainFrm.cpp文件,给UINT indicators[]数组增加显示“第二个信息行窗格”的标识:ID_SEPARATOR,;
用“类向导”为“用户视图类”添加OnCommand消息映射函数,并添加“先获得状态栏对象的指针,然后调用SetPaneText函数更新第二个窗格文本信息”的代码;
为“用户视图类”的OnInitialUpdate函数添加“获取记录总数”的相关代码;
在用户视图.cpp文件的头部添加包含语句:#include “MainFrm.h
您可能关注的文档
最近下载
- DB41T 2431-2023 重点区域地质灾害风险调查评价规范(1:10000).docx VIP
- 2012 INTERNATIONAL BUILDING CODE (2012年国际建筑规范).pdf VIP
- 金龙湖养老度假基地可行性报告.doc VIP
- 光伏发电工程施工规范.docx VIP
- 渗透检测工艺规程.pptx VIP
- 质量员考试(市政质量)基础知识试卷真题(2025年新版附解析).docx VIP
- 幼儿园课件:变焦PPT.ppt
- KEF音响无线HiFi扬声器LS50 Wireless II用户手册.pdf VIP
- 一种低气味、低刺激双固化胶粘剂及其制备方法.pdf VIP
- 设计机构设置和岗位职责.docx VIP
文档评论(0)