第10章 数据库编程.ppt
第10章 数据库编程 学习目标建立ODBC数据源了解类CDatabase、CRecordSet的使用方法创建Windows Explore风格的程序进一步熟练树控件和列表控件的使用10.1 MFC提供的ODBC数据库类 1.Visual C+数据库编程概述 ODBC APIMFC ODBCDAOOLE DBADO 第10章 多线程2.CDatabase类 Open()IsOpen()Close()第10章 多线程10.1 MFC提供的ODBC数据库类例:CDatabase db;if(!db.IsOpen()/判断db是否处于打开状态if(!db.Open(“Caie”)AfxMessageBox(“建立数据库连接失败!”)db.Close();3.CRecordSet类 第10章 多线程10.1 MFC提供的ODBC数据库类 CRecordSet类对象提供了从数据源中提取出的记录集。在实际应用程序中,一般不直接使用CRecordSet类,而是从CRecordSet类产生一个派生类,并添加相应于数据库表中字段的成员变量。10.2 本章实例第10章 多线程1.实例介绍 实例程序是“汽车及汽车零部件企业查询系统”,主要功能就是查询某个地区生产某产品的企业。单击工具栏的“打印”按钮,打印所查询出来的公司清单。第10章 多线程10.2 本章实例 双击右侧窗口列表中的某个公司编码,弹出对话框来显示该公司的详细信息。单击“打印”或“打印信封标签”按钮打印公司的详细信息或信封标签。第10章 多线程10.2 本章实例(1)代码设计 产品编码:*如2 1 0 2 地区编码:*如0 1 0 0 企业编码:*如0 1 0 0 0 0 1 2 系统设计 汽车零部件 汽车发动机系统 泵类零部件 北京未用序号(2)数据库设计地区编码表(Dqbm)产品编码表(Cpbm)公司情况表(Gsqk)产品情况表(Cpqk)本系统使用Access数据库,数据库名Caie.mdb第10章 多线程10.2 本章实例(1)用户DSN(2)Driver do Microsoft Access(*.mdb)(3)数据源名:Caie”3 创建ODBC数据源 10.3 程序实现 第10章 多线程1.创建工程Odbc2.创建与数据库表相关联的类3.处理工具栏4.处理左边窗口 5.处理右边窗口 6.初始封面 7.公司详细情况对话框 8.处理状态栏 步骤1 创建工程Odbc第10章 多线程(1)单文档(2)数据库:Header files only 可以在工程的在stdAfx.h文件中找到相应的代码如下:#include /MFC ODBC database classes(3)界面风格:Windows explore10.3 程序实现 步骤2 创建与数据库表相关联的类第10章 多线程添加以下4个与数据库表相关联的类:CRecordSet,CCpbmSet,CGsqkSet,CCpqkSet 方法:插入新类选择基类CRecordSet选择ODBC数据源,并选择Caie选择4个相应的表 10.3 程序实现 步骤3 处理工具栏1第10章 多线程(1)除“打印”按钮外,将工具栏上的所有按钮删除,载添加一个按钮,ID为ID_COMBOBOX。(2)载主框架类中定义组合框成员变量CComboBox m_ComboBox;(3)在主框架类的OnCreat()函数中创建工具栏代码的下面添加创建组合框的代码。10.3 程序实现 AddItemFromDqbm()调用步骤3 处理工具栏2第10章 多线程(4)添加AddItemFromDqbm()函数。在主框架类中添加成员函数AddItemFromDqbm()在主框架类中添加一个公有数据成员m_strDqbm,用来保存所选择地区的编码。CString m_strDqbm;在主框架类的实现文件的开始位置加入文件包含。#include DqbmSet.h#include Cpqkset.h10.3 程序实现 步骤3 处理工具栏3第10章 多线程(5)添加组合框的消息响应函数OnSelChangeCombo()原型:afx_msg void OnSelChangeCombo();消息映射:ON_CBN_SELCHANGE(ID_COMBOBOX,OnSelChangeCombo)函数定义:void CMainFrame:OnSelChangeCombo()CString strComboItem;m_ComboBox.GetWindowText(strComboItem);m_strDqbm=strComboItem.Left(4);COdbcView*pView=GetRightPane();pView-ListBuild();10.3 程序实现 本函数在后面介绍步骤3 处理工具栏4第10章 多线程(6)在主框架类中添加成员函数GetLeftPane()CLeftView*CMainFrame:GetLeftPane()CWnd*pWnd=m_wndSplitter.GetPane(0,0);CLeftView*pView=DYNAMIC_DOWNCAST(CLeftView,pWnd);return pView;在主框架类头文件中,添加CLeftView类的声明class CLeftView;10.3 程序实现 步骤4 处理左边窗口1 第10章 多线程(1)添加资源和成员变量IDI_CAR1,IDI_CAR2,IDI_CAR3,IDI_CAR4 10.3 程序实现 在视类中添加CImageList成员变量class CLeftView:public CTreeViewprotected:CImageList m_ImageList;在LeftView.cpp中添加:#include CpbmSet.h 步骤4 处理左边窗口2第10章 多线程(2)设置视中树控件的风格10.3 程序实现 在CLeftView类的PreCreateWindow()函数中添加代码 BOOL CLeftView:PreCreateWindow(CREATESTRUCT&cs)cs.style|=TVS_HASLINES|TVS_HASBUTTONS|TVS_LINESATROOT|TVS_SHOWSELALWAYS;return CTreeView:PreCreateWindow(cs);步骤4 处理左边窗口3第10章 多线程10.3 程序实现(3)在CLeftView:OnInitialUpdate()中建立树控件节点(4)添加消息响应函数函数CLeftView:OnSelchanged()在CLeftView 类中添加两个成员变量class CLeftView:public CTreeView public:CString m_strCpbm;long m_nCurlParam;在LeftView.cpp类中添加文件包含:#include MainFrm.h“#include OdbcView.h步骤5 处理右边窗口1 第10章 多线程10.3 程序实现(1)设置列表视的风格为report BOOL COdbcView:PreCreateWindow(CREATESTRUCT&cs)cs.style|=LVS_REPORT;return CListView:PreCreateWindow(cs);步骤5 处理右边窗口2 第10章 多线程10.3 程序实现(2)在OnInitialUpdate()函数创建列表控件的列 void COdbcView:OnInitialUpdate()CListView:OnInitialUpdate();CListCtrl&refList=GetListCtrl();refList.InsertColumn(0,公司编码,LVCFMT_LEFT,60);refList.InsertColumn(1,公司名称,LVCFMT_LEFT,240);refList.InsertColumn(2,联系电话,LVCFMT_LEFT,100);refList.InsertColumn(3,邮政编码,LVCFMT_LEFT,60);refList.InsertColumn(4,通信地址,LVCFMT_LEFT,300);步骤5 处理右边窗口3 第10章 多线程10.3 程序实现(3)添加COdbcView:ListBuild()函数 在OdbcView.cpp文件中添加以下文件包:#include MainFrm.h#include LeftView.h#include DqbmSet.h#include Cpqkset.h#include Gsqkset.h步骤6 初始封面 第10章 多线程10.3 程序实现 (1)选择菜单ProjectAdd To ProjectComponents And Controls,弹出Components And Controls Gallery对话框。(2)双击Visual C+Components,选择Splash screen,单击“Insert”按钮,再单击“确定”按钮。然后关闭Components And Controls Gallery对话框。(3)可以在工程文件夹中找到位图“Splsh16.bmp”,如果要使用自己制作的封面,只要替换这个位图即可。步骤7 公司详细情况对话框1 第10章 多线程10.3 程序实现(1)编辑对话框资源。ID:IDD_DLG_COMPINFO 编辑框的IDIDC_EDIT_NAME IDC_EDIT_POSTIDC_EDIT_ADRRESS IDC_EDIT_TELEPHONEIDC_EDIT_CZH IDC_EDIT_FRDBIDC_EDIT_EMAILIDC_EDIT_PPIDC_EDIT_QYGMIDC_EDIT_CPQK 步骤7 公司详细情况对话框2 第10章 多线程10.3 程序实现(2)为文本框控件添加关联变量 IDC_EDIT_ADRRESS CStringm_strAddress;IDC_EDIT_CPQK CStringm_strCpqk;IDC_EDIT_CZH CStringm_strFax;IDC_EDIT_EMAIL CStringm_strEmail;IDC_EDIT_FRDB CStringm_strFrdb;IDC_EDIT_NAME CStringm_strName;IDC_EDIT_POSTCStringm_strPostNumber;IDC_EDIT_PP CStringm_strPp;IDC_EDIT_QYGM CStringm_strQygm;IDC_EDIT_TELEPHONE CStringm_strTelephone;步骤7 公司详细情况对话框3 第10章 多线程10.3 程序实现(3)在对话框中添加私有成员变量m_strGsbm,并初始化 CDlgCompinfo:CDlgCompinfo(CString gsbm,CWnd*pParent/*=NULL*/):CDialog(CDlgCompinfo:IDD,pParent)m_strGsbm=gsbm;步骤7 公司详细情况对话框4 第10章 多线程10.3 程序实现(4)显示对话框 函数COdbcView:OnLButtonDblClk()(5)将公司的详细信息显示在对话框中 函数CDlgCompinfo:OnInitDialog()在OdbcView.cpp中添加文件包含:#include DlgCompinfo.h“在对话框类的实现文件中添加文件包含:#include GsqkSet.h 步骤8 处理状态栏1 第10章 多线程10.3 程序实现 (1)将主框架类中的保护成员变量m_wndStatusBar改为公有成员。(2)在主框架类的实现文件中找到indicators数组,再添加一个ID_SEPARATOR (3)设置状态栏前两个指示器的风格 在CMainFrame:OnCreate()添加以下代码:m_wndStatusBar.SetPaneInfo(0,ID_STATUSBAR,SBPS_NORMAL,10);m_wndStatusBar.SetPaneInfo(1,ID_STATUSBAR,SBPS_NORMAL,600);(4)在状态栏显示查询过程 在函数ListBuild()的第三行下面添加如下两行代码。CString strMess=正在查询,请稍候.;pMainFrame-m_wndStatusBar.SetPaneText(1,strMess);步骤8 处理状态栏2 第10章 多线程10.3 程序实现 在函数ListBuild()查询的循环里面添加下面的代码 nItemNumber+;if(nItemNumber%100=0)strMess+=.;pMainFrame-m_wndStatusBar.SetPaneText(1,strMess);pGsqkSet-MoveNext();在函数ListBuild()的最后添加下面两行代码。strMess.Format(共有%d家公司,nItemNumber);pMainFrame-m_wndStatusBar.SetPaneText(1,strMess);小结小结CDatabase类CRecordSet类Tree控件List控件程序启动封面 在状态栏显示信息 第10章 多线程