《面向连锁超市管理系统的分布式数据库设计与实现.docx》由会员分享,可在线阅读,更多相关《面向连锁超市管理系统的分布式数据库设计与实现.docx(69页珍藏版)》请在三一办公上搜索。
1、分布式数据库课程设计与实现面向连锁超市管理系统的分布式数据库设计与实现65目录1.连锁超市管理系统概述11.1背景介绍11.2 可行性分析11.3系统目标和先进之处21.4 小组成员和任务分配32.需求分析42.1用户需求概述42.2 业务需求分析52.3功能分析63.系统总体设计83.1绘制用例图设计系统功能83.2绘制系统流程图93.3 系统开发环境103.4系统的运行环境113.5 系统运行演示113.6系统类库设计144.分布式数据库分析与设计164.1数据库分析164.2数据库概念设计164.3数据库逻辑结构设计204.4 分片与位置分配设计244.4.1站点通信模型244.4.2数
2、据表的分片与位置分配设计255.基于SQL的SMS的详细设计(实现)275.1公共类设计275.1.1文件操作类CFileOperate275.1.2时间格式转换类CMyTime295.1.3数据操作类CADOConn295.1.4数据库表的操作类CtablePartInfo375.2界面窗口设计415.2.1系统启动登录开发415.2.2主界面对话框设计435.2.3通用报表对话框设计开发445.2.4打印对话框设计开发465.3基本资料模块设计485.3.1 基本资料管理功能开发48.2 价格自动生成功能开发525.3.3 报表功能实现545.4进货/销售模块设计555.4.1进货/销售登
3、记设计555.4.2进货设计595.4.3月度统计设计615.5库存模块设计625.5.1 库存查询功能开发625.5.2 库存报警功能开发636.开发技巧和难点分析646.1OLE技术使用646.2MFC Grid Control控件的使用651. 连锁超市管理系统概述1.1 背景介绍 随着市场经济的发展和人民生活水平的提高,原来单一、小规模的超市已无法满足人民对购物环境的要求,大规模、物品丰富的超市正在蓬勃发展。超市销售数据规模的日益庞大,商品数目的迅速增长,采用以往的手工管理已直接或间接地降低了工作效率,最终影响超市的日常运转。另外超市的发张壮大,尤其是连锁超市(如家乐福、美廉美)的扩张
4、,使得他们具有地域上分散而管理上又相对集中的特点,往往既要有各门店的局部控制和分散管理,同时也要有整个组织的全局控制和高层次的协同管理。因此把这些门店和中心通过网络连接起来,设计开发一款基于分布式数据库的连锁超市管理系统SMS(Supermarket management system)势在必行。1.2 可行性分析(1)经济可行性使用连锁超市管理系统对超市连锁店进行信息化管理将直接提高公司管理部门的工作效率。通过网络远程提交汇总各门店的信息,节省了许多的时间和金钱。另一方面,用信息化管理统计大量数据,节省了很多的人力和财力,为管理者提供更好的决策支持。(2)技术可行性 网络应用基础设施完善,由
5、于信息技术的发展,我国的计算机网络飞速发展,先后建成了中国公众多媒体通信网、China Net、 中国教育与科研计算机网络等组成了中国Internet主体,网络应用进入企业与普通家庭,这为发展连锁超市网络办公提供了基础设施。 网络安全技术应用,包括加密算法、CA数字认证、数字签名等,为网络办公系统的应用提供安全保证,它实现了网络传输数据的安全性、完整性等。 最后,就是网络技术的普及与掌握,如网络互联、网络安全技术、网络数据库技术等,使我们有能力开发实现适合自己的管理系统。因此,公司构建跨区域的管理系统的技术瓶颈问题(网络应用基础设施、网络安全、开发技术)得到了有效解决,公司构建网络管理系统技术
6、上可行。(3)操作可行性由于SMS的操作是基于C/S的客户端的页面操作,简单明了,用户无需学习,一般都能够很容易的知道如何操作。而管理员也无需具备专业知识,只需要对一些数据进行输入以及平时的日常维护就够了。1.3系统目标和先进之处 (1)系统目标为连锁超市提高效率、降低成本;实现连锁超市管理的优化,简化工作流程,节省人力物力,提高工作效率,极大地满足客户需要;对各环节进行控制分析,实现统一调度。满足连锁超市的基本管理功能,发挥信息系统的灵活性,减轻企业管理人员和操作人员的工作负担,提高工作效率。 本系统是一项功能比较完善的连锁超市管理系统,对连锁店运作过程中的后台数据可以随时进行分析,便于企业
7、管理人员的经营、决策。 全面体现了现代企业管理理论所倡导的工作高效、环境轻松的氛围。(2)系统先进之处 多数处理就地完成。 各地的计算机由数据通信网络相联系。 克服了中心数据库的弱点:降低了数据传输代价。 提高了系统的可靠性,局部系统发生故障,其他部分还可继续工作。 各个数据库的位置是透明的,方便系统的扩充。 为了协调整个系统的事务活动,事务管理的性能花费高。1.4 小组成员和任务分配 2.1用户需求概述 下面是通过调查研究获得的关于连锁超市主要信息数据的需求分析结果:(1) 连锁超市通常由一个中心(公司总部)、多个远程连锁店(门店)组成,并且每个连锁店分布在不同地域。 (2)连锁超市的各个部
8、门之间、各个分店之间、分店与总部之间需要交换数据,这种数据交换是通过局域网和广域网进行的。(3)公司总部负责产生并管理该连锁超市的整体汇总数据,即各门店的明细汇总表数据,如销售汇总表等。(4)每一个远程站点(各门店和公司总部)分别有一个数据库系统,各自组成一个独立的子系统,可以分别独立进行本部门业务处理。(5)总部为了便于对各店进行管理,同时也为了比较各店的销售情况,要求门店将所有商品归入相应的商品类别,由总部统一管理并提供各门店使用,而且,商品类别信息数据在各门店都要经常使用。(6)有关商品信息、供应商信息、POS机信息、进货信息和销售信息等经营基础数据都是各门店单独管理和使用,门店之间互不
9、相关。(7)整个连锁超市的职员信息由公司总部管理和维护,各门店只可以查询本部门的职员信息。2.2 业务需求分析通过对超市的营业、管理业务流程的调查,得到下面的业务需求。 可以对商品类别、商品、供应商、POS机等基础信息进行管理。 可以实现采购开单、销售开单、采购退货、销售退货等基本功能。 软件可根据商品资料中设置的最高库存、最低库存进行库存报警。 商品的批发价、零售价可自动生成,减轻定价的工作量。 可以生成各类统计报表,提供详尽的营业报告,实现对商品进、销、存及利润等财务状况了如指掌。 所有单据、报表均可以在打印前预览,并且可以导出为Excel文件,然后根据实际需要进行特别的编排处理。 为了系
10、统安全,每次用户登录都创建相应的日志文件,记录用户的所有操作。此外,对系统的性能主要有以下几个方面的需求。系统在设计过程中应充分考虑到可扩充性,要求操作界面美观大方,容易上手。2.3功能分析根据对系统的业务调查和用户的需求分析,结合计算机信息管理的特点,设计系统实现的功能如下。(1) 基础信息管理基础信息管理包括业种商品类别信息、商品信息、供应商信息、POS机信息和价格信息维护与管理,实现的功能包括: 基本信息的添加、删除和更新操作。 生成各类基础信息报表。 打印和导出报表。(2) 进货管理进货管理主要实现对商品的采购入库信息进行管理,具体实现功能如下: 进货开单,实现商品的进货结算、入库操作
11、。 进货退货,退还商家相关的商品。 生成进货、退货的单据、商品报表。 打印和导出报表。(3) 销售管理销售管理主要实现对商品的销售出库相关信息进行管理,具体实现的功能如下: 销售开单,实现商品的销售结算、出库操作。 销售退货,允许客户退出相关的商品。 生成销售、销售退货的单据、商品报表。 打印和导出报表。(4) 库存管理库存管理主要实现对商品的库存相关信息进行管理,具体实现的功能如下: 库存查询,可以查看所有库存商品的相关信息。 库存报警,对库存过多或过少的商品进行报表统计。 库存盘点,可以修改商品的库存数量。(5) 帐务管理帐务管理主要实现对营业员的销售商品、业务提成、营业收入等情况进行分类
12、报表统计。(6) 数据管理数据管理主要实现对数据库数据进行备份、还原及清理等相关工作。(7) 系统管理系统管理主要实现登录用户(职员)管理、系统日志、修改登录密码等相关工作。2. 系统总体设计3.1绘制用例图设计系统功能用例图表示了角色和用例以及它们之间的关系。它描述了系统、子系统和类的一致的功能集合,表现为系统和一个或多个外部交互者(角色)的消息交互动作序列。也就是角色(用户或外部系统)和系统(要设计的系统)为了实现一个目的交互,这个目的的描述通常是一个谓词短语,例如签合同等。系统设计包含超级管理员、管理员和营业员四种用户角色。超级管理员具有所有的操作权限,其用例图如图3-1所示。图3-1
13、超级管理员角色系统用例图管理员不具备系统设置模块中的用户管理和商品类别信息管理功能,其他功能均具备。而销售人员则只具有销售开单管理功能。3.2绘制系统流程图结合系统的具体设计要求,连锁超市管理系统的主要功能流程图如图3-2所示。图3-2 系统主要功能流程图系统首先对登录用户身份进行验证,根据用户的权限激活相关功能。超级管理员具有所有的操作权限,系统的功能结构图如图3-3所示。图3-3 系统功能结构图上图只是列出了一些主要功能,系统还能够根据不同需求生成各种统计报表。3.3 系统开发环境 本系统是在Windows XP中文版操作系统环境下,使用Microsoft Visual Studio 20
14、08中文版用C+语言开发成功的。在开发过程中,使用了OLE技术和ActiveX控件技术。后台数据库系统设计采用的是Microsoft的 SQL Server 2005和Access数据库系统,通过ADO数据库开发技术,直接操作数据库文件。3.4系统的运行环境系统可以直接在Win98、Win2000、WinXP环境下运行。系统预设的超级管理员用户名为“admin”,密码为“admin”。3.5 系统运行演示程序启动,首先弹出如图3-4所示的“系统登录”对话框,只有输入正确的用户ID、登录密码才能进入系统能够。图3-4 “系统登录”对话框如果登录用户为超级管理员或管理员,会进入系统的主界面窗口,如
15、图3-5所示。图3-5 系统的主界面窗口如果登录用户权限为营业员,由于其只具有售货权限,因此系统会直接弹出“销售开单”对话框,如图3-6所示。图3-6 “销售开单”对话框在进行相关操作前,首先需要添加、设置一些基本资料,如商品分类登记,其操作设置对话框,如图3-7所示。图3-7 “商品分类登记”对话框另外,系统还提供了丰富的报表功能,如图3-8所示的商品分类报表,同时对报表提供了导出到Excel文件和打印的功能。图3-8 商品分类报表对话框3.6系统类库设计 BITVRLab超市管理系统主框架的设计是通过MFC创建向导创建的基于对话框的窗口程序,在对话框程序中添加了菜单栏,系统的主要类库设计如
16、下。 自定义扩展类:为了提高开发效率、便于代码重用,自定义了一些数据操作类和控件扩展类,如表3-1所示。表3-1 自定义扩展类及功能类说 明CADOConn通过ADO实现对ACCESS、SqlServer等数据库的访问CtablePartInfo根据数据库表的分配、分片信息,实现对数据库表的增、删、改、查CFileOperate实现对硬盘文件的常用操作CMyChiToLetter实现根据逐字提取汉字拼音的首字母CMyButtonCButton类的派生类,实现带有位图和文本的按钮CMyMenuCMenu类的派生类,用于定制自己的菜单CMenuItemContextCMenu类中用到此类,用于保存
17、菜单项的信息CMyTime实现简单的时间格式的转换CMyExcel完成VC对Excel文件的操作 对话框窗口类:在系统中,用户所有的数据查询、操作都是通过对话框窗口来实现的,系统开发的对话框类如表3-2所示。表3-2 对话框类及说明类说 明CDlgFenJiBasePOS机基本信息管理对话框类CShopManageDlg主框架对话框类CDlgFenLeiBase商品分类基本信息管理对话框类CDlgDanganBase商品基本信息管理对话框类CDlgGongYingShangBase供应商基本信息管理对话框GDlgJiaGeSheZhi价格自动设置对话框类CDlgJinHuoKanDan商品进货
18、开单管理对话框类CDlgJinHuoTuiDan商品进货退单管理对话框类CDlgXiaoShouKanDan商品销售开单管理对话框类CDlgXiaoShouTuiDan商品销售退单管理对话框类CDlgAll用于查找信息显示对话框类CDlgReport用于报表显示对话框类CDlgLogo用户登录对话框类CDlgPwd更改密码对话框类CDlgQuit退出系统提示对话框类 打印相关类:系统能够提供了报表的打印和打印预览功能,其相关的设计类如表3-3所示。表3-3 打印相关类及说明类说 明CPrintFrameCFrameWnd派生类,用于构建打印框架类CPrintView打印视图类另外,系统还包含一
19、些主框架相关类、导入ActiveX控件(MFC Grid Control)相关类和导入OLE对象(Excel)相关类。3. 分布式数据库分析与设计 4.1数据库分析考虑到总站点的信息量大采用SQL Server2005数据库,而区域站点信息量相对较小采用Access数据库。当区域业务拓展,操作终端增加时,Access数据库也很容易的移植到SQL Server数据库系统中。另外区域站点采用Access数据库可以实现方便的部署。4.2数据库概念设计分析超市管理功能流程,系统的数据实体主要包括基本资料对象实体、库存实体、进货/销售开单、进货/销售退单、进货/销售商品实体、各站点数据库服务器IP信息实
20、体、数据库表分配分片信息实体等。 基本资料对象实体包括商品类别、商品明细、供应商、POS机和登录用户实体。 商品库存实体记录库存商品的数量和价格信息,其实体的E-R图如下。 商品进货单实体用于记录进货单的统计信息,其实体的E-R图如下所示。 进货商品实体用于记录进货单对应的商品信息,其实体的E-R图如下所示。 进货退单实体用于记录进货退单信息,其实体的E-R图如下所示。与进货相对应的销售单实体、销售商品实体和销售退单实体的E-R图如下所示。 各站点数据库服务器IP信息,记录各个区域数据库服务器对应的IP地址,其实体的E-R图,如下图所示。 数据库表分配分片信息,记录数据中所有的表的分布式分配和
21、分片信息,其实体E-R图,如图所示。4.3数据库逻辑结构设计商品类别表、商品明细表、供应商表、POS机表、登录用户表、库存表、进货/销售开单表、进货/销售商品表、进货/销售退货商品表、IP地址登录信息表、数据库表的分配和分片信息。商品类别表:商品明细表:供应商表:POS机表:用户表:库存表:进货单表:进货商品表:进货商品退单表:销售单表:销售商品表:销售商品退单表:服务器IP信息表:分片及分布信息表:4.4 分片与位置分配设计 4.4.1站点通信模型在我们的连锁超市管理系统中,有一个总店并下分多个分店,总店和分店之间或分店与分店之间都可以进行通信。每个分店是一个相对独立的数据库服务系统,其可以
22、连接任意数量的客户端。通信模型如下图所示:4.4.2数据表的分片与位置分配设计根据以上得到的关于主要信息数据的需求分析结果,为该连锁超市系统的分布式数据库系统进行主要信息数据的分片和分配设计如下:1、数据的分片设计(1)由于该连锁超市系统的各连锁店之间在经营上是独立的,每个门店只关心自己的经营状况,有关供应商信息、POS机信息、商品信息和进货/销货信息等基础数据都是各门店单独管理和使用,门店之间互不相关。因此,商品明细表、供应商表、POS机表、库存表、进货/销售开单表、进货/销售商品表、进货/销售退货商品表按照地域(门店所在区域标志)采用水平分片的方法得到水平片段。(2)这里我们对于商品信息进
23、行了垂直分片,分成了商品明细表和库存表,因为商品的某些属性,例如库存量等需要经常更新,因此将这些属性划分出来构成单独的实体可以减少系统开销。(3)由于整个连锁超市的职员信息由总公司管理和维护,各门店只可以查询本店的职员信息。所以职员信息不必分片,可以采用视图的形式提供给各门店查询本门店的职员信息。另外,各个区域数据库服务器的IP地址信息也只是由总部管理、维护,所以也不必分片。(4)由于商品分类数据由总部统一管理并提供各门店使用,而且,商品类别信息数据在各门店都要经常使用。因此,商品类别信息数据也不必分片。(5)该分布式数据库系统实现了简单的目录管理,记录数据库中各个表的分片和分配信息,以便数据
24、更新时,维护各个站点上数据的一致性。这个表由总部规划建立,各门店也会经常使用。因此,数据库目录信息表也不必分片。2、数据及其片段的分配设计(1)对于只在各门店单独使用的除商品类别信息和数据库目录信息以外的其他基础信息的片段,采用按区域分片然后分配到各个门店的数据库服务器上。总站上有所有门店的所有信息。(2)整个系统的职员信息、IP地址信息由公司总部管理和维护,所以只分配在总部站点中。(3)商品类别信息、数据库目录信息是由总部统一规定并下发到各门店的,由于各店经常会使用到这类基础信息,因此在各门店都具有相同的副本。所以,商品类别信息、数据库目录信息都不会分片但被复制,且复制的个数为门店的个数。4
25、. 基于SQL的SMS的详细设计(实现)5.1公共类设计为了提高程序代码的开发效率,便于代码重用,在系统开发中,创建了一些数据操作类和控件扩展类。5.1.1文件操作类CFileOperate为了便于对硬盘文件的操作,开发了文件操作类CFileOperate,它通过调用API函数实现常用的文件操作。CFileOperate类的声明代码如下。extern CString strTmpPath;class CFileOperatepublic:/构造函数CFileOperate();/取得当前程序运行的路径CString GetAppPath();/判断是否存在strFn文件夹BOOL IsFile
26、Exist(CString strFn, BOOL bDir);/制作strFloderName文件夹返回文件夹名CString MakeDirectory(CString strFloderName);/自动生成文件夹CString MakeDirectory();/得到文件夹名为strFloderName的路径CString GetDirectoryPath(CString strFloderName);/删除strFloderdName文件夹void delDirectory(CString strFloderdName);/删除主文件夹(data)void delMainDirecto
27、ry();/制作主文件夹void MakeMainDirectory();/判断strIntDigit是否为整数,是否小于intBigBOOL CheckIntDigit(CString strIntDigit,int intBig);/判断strFileName是否可以做文件夹或文件的名字BOOL CheckFileName(CString strFileName);/判断strText是否为空BOOL CheckEmpty(CString strText);/删除strFloderName文件夹下名为strFileName的文件void delFile(CString strFloderN
28、ame,CString strFileName);/得到strFloderName文件夹下名为strFileName的文件路径CString GetFileName(CString strFolderName,CString strFileName);/制作strFloderName文件夹下名为strFileName的文件CString MakeFile(CString strFloderName,BOOL blnMake);/显示文件夹对话框BOOL GetFolder(CString* strSelectedFolder,const char* lpszTitle,const HWND h
29、wndOwner,const char* strRootFolder,const char* strStartFolder);系统程序中主要用到了CFileOperate类中的GetAppPath函数。GetAppPath函数用于获取当前运行程序所在文件夹的路径,其实现代码如下。CString CFileOperate:GetAppPath()/取得当前运行程序所在文件夹路径char lpFileNameMAX_PATH;/路径数组/获取当前运行程序的全路径GetModuleFileName(AfxGetInstanceHandle(),lpFileName,MAX_PATH);CString
30、 strFileName = lpFileName;/从字符串的最右边向左搜索串int nIndex = strFileName.ReverseFind ();CString strPath;if (nIndex 0)strPath = strFileName.Left (nIndex);/取串左边字符elsestrPath = ;return strPath;/返回前运行程序的文件夹路径5.1.2时间格式转换类CMyTime系统开发中,需要频繁的对日期、时间数据进行操作,因此这里设计了类CMyTime,实现简单的时间日期转换,CMyTime类的声明如下。class CMyTimepublic
31、:CTime ValueTime;/CTime类型的值/blnChinese:TRUE-年月日时分秒 FALSE-:CString GetAllString(BOOL blnChinese);/返回字符串形式的日期时间/blnChinese:TRUE-年月日 FALSE-CString GetDateString(BOOL blnChinese);/返回字符串形式的日期/blnChinese:TRUE-时分秒 FALSE-:CString GetTimeString(BOOL blnChinese);/返回字符串形式的时间CString GetSimpleString();/返回简单字符串形式
32、的日期时间CString GetWeek();/返回星期星期日/设置字符串形式的值/blnSimple:TRUE-(%Y%m%d%H%M%S) FALSE-(年月日时分秒或-:)void SetAllString(CString Value,BOOL blnSimple);void SetNow();/设置成现在时间CMyTime();/构造函数;SetNow函数获取当前日期,时间,将其值赋予ValueTime。void CMyTime:SetNow()ValueTime=CTime:GetCurrentTime();5.1.3数据操作类CADOConn系统开发了数据操作类CADOConn,它
33、是本系统的核心,实现了对数据库数据的基本操作功能,CADOConn类的声明代码如下。#import c:program filescommon filessystemadomsado15.dll no_namespace rename (EOF, adoEOF)class CADOConn / 定义变量public:_ConnectionPtr m_pConnection;/指向Connection对象指针:/添加一个指向Recordset对象的指针:_RecordsetPtr m_pRecordset;_bstr_t m_strData;int m_DataType;CADOConn(int
34、 DataType);/构造函数CADOConn();virtual CADOConn();void OnInitCADOConn();/初始化连接数据库_RecordsetPtr& GetRecordSet(CString strSQL);/执行查询BOOL ExecuteSQL(CString strSQL);/执行SQL语句,Insert Update deletevoid ExitConnect();/退出连接BOOL MoveFirst();/字段集移向开头BOOL MoveNext();/字段集向下移BOOL Open(CString strSQL);/打开记录集BOOL Open
35、Logo(CString strSQL);/打开记录集CString GetValueString(int index,int strSum);/返回记录集中某字段的字符串byte GetValueByte(int index);/返回记录集中某字段的字节int GetValueInt(int index);/返回记录集中某字段的短整数double GetValueDouble(int index);/返回记录集中某字段的双精度数float GetValueFloat(int index);/返回记录集中某字段的单精度数long GetValueLong(int index);/返回记录集中某
36、字段的长整型数CTime GetValueDate(int index);/返回记录集中某字段的日期时间/获取记录集某字段的BYTE值,并换为CString返回CString GetValueByteStr(int index,int strSum);/获取记录集某字段的INT值,并换为CString返回CString GetValueIntStr(int index,int strSum);/获取记录集某字段的Double值,并换为CString返回CString GetValueDoubleStr(int index,int strLSum,int strRSum);/获取记录集某字段的F
37、loat值,并换为CString返回CString GetValueFloatStr(int index,int strLSum,int strRSum);/获取记录集某字段的Long值,并换为CString返回CString GetValueLongStr(int index,int strSum);/获取记录集某字段的CTime值,并换为CString返回CString GetValueDateStr(int index,CString strType);/添加单项数据BOOL AddItem(CString strTable,int strSum,LPCTSTR pszText, . )
38、;/得到字段中数据的类型int GetValueType(int index);BOOL adoEOF();/记录集的结束判断BOOL FillList(CListCtrl *listMain,int ColOpenEnd);/填充列表(ColOpenEnd代表展开多少列)BOOL InitList(CListCtrl *listMain,int colSum);/初始化列表CString GetAppPath();/得到应用程序所在的文件夹BOOL FillList(CListCtrl *listMain);/填充列表CString GetFieldsName(int index);/返回字
39、段名字int GetFeildsCount();/返回字段数量/返回数据集数long GetRecordCount();void WriteLog(CString strSql);/写日志文件void WriteLog1(CString userName);/写日志文件,谁谁登录;1、数据库操作函数对常用的数据库操作定义了相关函数。(1)连接数据库在类的构造函数CADOConn中,声明数据库的名称。CADOConn:CADOConn()m_DataType=1;/数据库类型Acessm_strData= _bstr_t(ShopData.mdb);/数据库名称在OnInitCADOConn函数
40、中,实现连接数据库。void CADOConn:OnInitCADOConn()/ 初始化OLE/COM库环境:CoInitialize(NULL); try/初始化指针m_pConnection=NULL;/初始化指针m_pRecordset=NULL;/ 创建Connection对象m_pConnection.CreateInstance(ADODB.Connection);/ 设置连接字符串,必须是BSTR型或者_bstr_t类型_bstr_t strConnect;switch(m_DataType)case 1:/ACCESSstrConnect=_bstr_t(Provider=M
41、icrosoft.Jet.OLEDB.4.0;);strConnect=strConnect+_bstr_t(Data Source=);strConnect=strConnect+_bstr_t(IPAddress)+_bstr_t(data);strConnect=strConnect+m_strData;break;case 2:/EXCELstrConnect=_bstr_t(Provider=Microsoft.Jet.OLEDB.4.0;);strConnect=strConnect+_bstr_t(Data Source=);strConnect=strConnect+_bstr
42、_t(GetAppPath()+_bstr_t();strConnect=strConnect+m_strData;strConnect=strConnect+;Extended Properties=Excel 8.0;break;case 3:/SQLSERVERstrConnect=Provider=SQLOLEDB; Server=+MainIP+;Database=ShopData; uid=admin; pwd=123456;break;m_pConnection-Open(strConnect,adModeUnknown);/ 捕捉异常catch(_com_error e)/ 显
43、示错误信息AfxMessageBox(e.Description();ASSERT(m_pConnection != NULL);(2)对数据库进行查询GetRecordSet函数实现执行Select查询语句,返回查询结果集_RecordsetPtr& CADOConn:GetRecordSet(CString strSQL)try/ 连接数据库,如果Connection对象为空,则重新连接数据库if(m_pConnection=NULL)OnInitCADOConn();strSQL.TrimLeft();strSQL.TrimRight();/ 创建记录集对象m_pRecordset.Cr
44、eateInstance(_uuidof(Recordset);/ 取得表中的记录m_pRecordset-Open(_bstr_t(strSQL),m_pConnection.GetInterfacePtr(),adOpenDynamic,adLockOptimistic,adCmdText);/ 捕捉异常catch(_com_error e)/ 显示错误信息AfxMessageBox(e.Description();ASSERT(m_pRecordset!= NULL);/ 返回记录集return m_pRecordset;CADOConn类的Open函数的实现与GetRecordSet函数基本类似,只是它不返回记录集,而是打开数据库表。(3)执行数据库操作语句ExecuteSQL函数实现执行SQL数据操作语句,如INSERT/UPDATE/DELETE语句等。BOOL CADOConn:ExecuteSQL(CString strSQL)try/