1、 第 1 页 共 84 页图书管理系统的建立摘 要二十一世纪是信息的社会,信息作为社会最主要的资源,将成为战略资源引起人们广泛的关注。如何获取信息?图书是我们最好的获取信息的方式,但由于图书馆图书收藏量大大增加,使传统的图书管理员的工作日益繁重起来。迫使人们起用新的管理方法来管理图书,如何把图书管理员从繁重的工作中解脱出来呢?科学技术日新月异的进步,让人类生活发生了巨大的变化,计算机技术的飞速发展,使各行各业在计算机技术应用方面得到了广泛的普及和使用。信息化时代的到来成为不可抗拒的潮流,人类文明正在进入一个崭新的时代。因此,图书管理系统也以方便、快捷、费用低的优点正慢慢地进入人们的生活,将传统
2、的图书管理方式彻底的解脱出来,提高效率,减轻工人人员以往繁忙的工作,减小出错的概率,使读者可以花更多的时间在选择书和看书上。从而使人们有更多时间来获取信息、了解信息、掌握信息 。关键词:图书管理 系统设计 信息 第 2 页 共 84 页Abstract21 centuries is resources that information that society, social most in conduct and actions in information, will become the strategy resources cause the extensive concern in
3、people.How to obtain the information?Books is work that the way that we obtain the information bestly, but collect and keep to have great capacity the big increment because of the library books, make traditional books managing person increasingly heavy to get up.Forcing people rises to manage the bo
4、oks with the new management method, howing to set free out the books the managing person from the heavy work?The advance of the science technique continuous changes and improvements, let mankind the life took place the enormous variety, the calculator flies technically to develop soon, making the ev
5、ery trade get the extensive universality with use in the aspects of calculator technique applying.The information turns the ages comes the current that become cant resist, human civilization enter a brand-new ages.Therefore, books management system too with the convenience, fast, low advantage in ex
6、penses is entering people life slowly, manage the traditional books to way to set free out thoroughly, lift high-efficiency, alleviate workers personnel former busy work, let up to come amiss all rate, can make the reader spend more time at choose the book with read the in the book.From but make tha
7、t people have more time to obtain the information, understand the information and control the information.Keyword:Books management、System design、 Informatio第 3 页 共 84 页目 录摘 要1目 录3第一章 导 论 .51.1 所用开发语言简介.61.1.1 VC+的特点 .61.1.2 VC+控件及其属性简介 .61.1.3 系统数据访问接口的选择.7第二章 系统分析阶段 72.1 系统功能模块 82.1.1 功能的实现 82.1.2
8、模块框架图 92.2 系统数据分析 .10第三章 设计阶段 .133.1 概要设计 .133.1.1 数据库概论及 SQL、ACCESS2000 简介 143.2 详细设计 .203.2.1 数据信息准备 .203.2.2 程序数据流图 .20第四章 设计思想 .274.1 面向对象的程序设计234.2 详细设计思想 .244.2.1“用户登录”模块设计. 244.2.2“基本资料”维护模块设计:264.3 “系统管理”模块设计.35第 4 页 共 84 页总结与展望 38结束语 .39参考文献 .39致谢语40附录:.42第 5 页 共 84 页第一章 导论一直以来人们使用传统的人工方式管理
9、图书馆的日常工作,对于图书馆的借书和还书过程,想必大家都已很熟悉。在计算机尚未在图书馆广泛使用之前,借书和还书过程主要依靠手工。一个最典型的手工处理还书过程就是:读者将要借的书和借阅证交给工作人员,工作人员将每本书上附带的描述书的信息的卡片和读者的借阅证放在一个小格栏里,并在借阅证和每本书贴的借阅条上填写借阅信息。这样借书过程就完成了。还书时,读者将要还的书交给工作人员,工作人员根据图书信息找到相应的书卡和借阅证,并填好相应的还书信息,这样还书过程就完成了。以上所描述的手工过程的不足之处显而易见,首先处理借书、还书业务流程的效率很低,其次处理能力比较低,一段时间内,所能服务的读者人数是有限的。
10、利用计算机来处理这些流程无疑会极大程度地提高效率和处理能力。我们将会看到排队等候借书、还书的队伍不再那么长,工作人员出错的概率也小了,读者可以花更多的时间在选择书和看书上。为方便对图书馆书籍、读者资料、借还书等进行高效的管理,特编写该程序以提高图书馆的管理效率。使用该程序之后,工作人员可以查询某位读者、某种图书的借阅情况,还可以对当前图书借阅情况进行一些统计,给出统计表格,以便全面掌握图书的流通情况。本次毕业设计题目:“图书管理系统”主要目的是利用数据库软件编制一个管理软件,用以实现图书、读者以及日常工作等多项管理。同时对整个系统的分析、设计过程给出一个完整论证。图书管理系统是一种基于集中统一
11、规划的数据库数据管理新模式。在对图书、第 6 页 共 84 页读者的管理,其实是对图书、读者数据的管理。本系统的建成无疑会为管理者对图书管理系统提供极大的帮助。本系统的设计主要从以下几方面做起:系统业务流程分析、系统的功能设计、系统的数据库结构设计、系统输入/输出设计等。作这些工作需对数据库知识有足够认识,并深入的了解 VC+6.0 的使用和管理系统的相关知识。在信息时代的今天,人类需要对在政治、经济、军事、文化、科研、教育等领域产生的大量信息进行管理,并对数据进行加工处理,数据库技术则是信息管理与数据处理的先进技术。随着信息量的不断增加,作为计算机的三大主要应用(科学计算、过程控制和数据处理
12、)之一的数据处理,已迅速上升为计算机应用的主要方面,数据库技术则成为人们日常生活中处理数据不可缺少的有力工具,并且现代的信息管理系统几乎都以数据库技术作为核心。1.1 所用开发语言简介1.1.1 VC+的特点Visual C+是功能最为强大可视化开发工具,它不仅支持传统的软件开发方法,更重要的是它能支持面向对象、可视化的开发风格。因此 Visual C+又称作是一个集成开发工具,它提供了软件代码自动生成和可视化的资源编辑功能。Visual C+具有的优点:提供了面向对象的应用程序框架 MFC(Microsoft Foundation Class),简化了程序员的编程工作,提高了模块的可重用性;
13、提供了基于 CASE 技术的可视化软件的自动生成和维护工具AppWizard、ClassWizard、Visual Studio、WizardBar 等,实现了直观、可视的程序设计风格,方便地编和管理各种类,维护程序的源代码;封装了 Windows 的API 函数、USER、KERNEL、GDI 函数,简化了编程时创建、维护窗口的许多复杂的工作。1.1.2 本程序中使用的 VC+控件及其属性简介(1)CStatic(静态控件):显示一些几乎固定不变的文字或图形描述。(2)CButton(按钮控件):产生某些命令或改变某些选项设置。(3)CEdit(编辑框控件):完成文字的输入输出双向操作,查看
14、并编辑文字。第 7 页 共 84 页(4)CListBox(列表框控件):显示一个列表,让用户从中选取一个或多个项。(5)CComboBox(组合框):将列表框和编辑框有机地组合在一起,可选择列表中已有的项,还可以编辑出新的项。1.1.3 系统数据访问接口的选择Visual C+中可用的数据访问对象接口有三种:ODBC(Open Database Connectity,开发数据库连接) 、DAO(Data Access Objects,数据访问对象)及 OLE DB(OLE data Base,OLE 数据库)。1ODBC(Open Database Connectity,开发数据库连接)OD
15、BC 提供了应用程序接口(API) ,使得任何一个数据库都可以通过 ODBC 驱动器与指定 DBMC 相联,用户的程序就可以通过调用 ODBC 驱动管理器中相应的驱动程序达到管理数据库的目的。作为 Microsoft Windows Open Standards Architecture(WOSA,Windows 开放式服务体系结构)的主要组成部分,ODBC 一直沿用至今。2.DAO(Data Access Objects,数据访问对象)DAO 提供了一种通过程序代码创建和操纵数据库的机制。多个 DAO 对象构成了一个体系结构,在这个结构里,各个 DAO 对象协同工作,通过 Microsoft
16、 Jet 数据库访问数据库中的数据和数据库的结构定义。可以访问的数据库类型主要有:Microsoft Jet 数据库、ODBC 数据源、可安装的 ISAM 数据库。DAO 是我们可以通过程序访问和操纵本地的或远程的数据和数据定义,管理数据库中的对象或结构。DAO 支持两种不同的数据库环境称为工作区(Workspace).Microsoft Jet Workspace 这是一种使用 Microsoft Jet 数据库引擎来访问数据源的工作区。ODBC Direct Workspace 这是一种使用 ODBC Direct 来直接访问一个 ODBC 数据源,并绕过 Microsoft Jet 数据
17、库引擎的工作区。可通过 ODBC 访问数据库服务器,而无须安装 Microsoft Jet 数据库引擎。3OLE DB(OLE data Base,OLE 数据库)。第 8 页 共 84 页OLE DB 试图提高一种统一的数据访问接口,并能处理除了标准的关系型数据库中的数据之外,还能处理包括邮件数据、Web 上的文本或图形、目录服务(Directory Services) ,以及主机系统中的 IMS 和 VSAM 数据。OLE DB 提供一个数据库编程 COM(组件对象模型)接口,使得数据的使用者(应用程序)可以使用同样的方法访问各种数据,而不用考虑数据的具体存储地点、格式或类型。这个 COM
18、 接口与 ODBC 相比,其健壮性和灵活性要高的多。但是,由于 OLE DB的程序比较复杂,因而对于一般用户来说使用 ODBC 和 DAO 方式已能满足一般数据库处理的需要。第 9 页 共 84 页第二章 需求分析阶段需求分析是在于要弄清用户对开发的数据库应用系统的确切要求。Visual C+ 数据库设计的第一步是明确数据库的目的和如何使用。也就是说需要从数据库中得到哪些信息。明确目的之后,就可以确定您需要保存哪些主题的信息(表) ,以及每个主题需要保存哪些信息(表中字段) 。要设计一个有效的数据库,必须用系统工程的观点来考虑问题。在系统分析阶段,设计者和用户双方要密切合作,共同收集和分析数据
19、管理中信息的内容和用户对处理的要求。根据系统分析,图书管理系统的要求如下 :(1)需求分析: 能够输入图书的综合情况和进行新书入库、现有图书信息修改以及删除; 能够实现对读者档案的查询和编辑管理; 能够进行罚款功能; 能够进行借阅历史的查询功能;(2)系统性能要求: 系统安全、可靠; 功能齐全; 操作方便、界面友好; 易于维护和扩充。(3)系统的功能分析:密码设置:每个操作员均有自己的密码,可以防止非本系统人员进入本系统;第 10 页 共 84 页又因每个人的权限不一致,故可以防止越权操作。资料维护:为了存放图书、读者档案的全部数据,本系统将每一本图书和每位读者的信息进行管理。系统维护包括对各
20、种表记录的修改、删除、添加等操作。系统查询:可以按图书编号、借阅证编号等相关信息进行查询系统管理:进行员工管理、数据备份和数据恢复。报表统计:包括统计图书信息、读者信息、借阅信息和罚款信息等。其它操作:包括修改密码、添加用户、页面设置等2.1 系统功能模块图书管理系统需要实现的功能主要有四大块:“日常工作管理” 、 “基本资料维护” 、 “查询” 、和“系统管理”模块。其中日常工作管理和基本资料维护是整个系统的核心。2.1.1 功能的实现:1 “日常工作”模块:(1) 借书处理:主要功能是记录借阅证编号和图书编号,进行借书过程。在数据库中插入一条借书记录,该记录包括读者 ID、图书 ID、借出
21、日期、还书期限、操作员姓名。(2) 还书处理:主要功能是输入借阅证编号、图书 ID,在借阅登记表中找到相应的记录,将该记录的相应数据插入到还书记录中,同时将借书记录删除,并保存在借阅历史记录表中。(3) 缴纳罚金:输入读者 ID,显示该读者的姓名、图书编号、罚款金额和罚款原因,如果读者交纳了罚金,则将借阅登记表的允许借阅标志置为“Y” 。删除罚款记录表中该读者对应的记录,将这一条记录同时插入到罚款历史记录表中。2 “基本资料维护”模块:(1)图书资料维护:包括新书的入库,以及现有书籍资料的修改和删除。(2)读者资料维护:包括新会员的资料入库,以及现有会员资料的修改和删除3 “查询”模块:第 1
22、1 页 共 84 页(1)图书资料查询:根据相应的图书信息对所有书籍进行所需查询。此查询包括:图书分类 、 图书编号 、 图书名称 、 作者 、 出版社 。(2)读者资料查询:根据相应的读者资料进行所需查询。 借阅证编号 、 读者姓名 以及身份证编号 。(3)借阅历史记录查询:根据相应的借阅信息进行所需查询。此查询包括:借阅证编号 、 图书编号 、 借书日期 、 还书日期 。(4)罚款历史记录查询:根据相应的罚款信息进行所需查询。此查询包括:借阅证编号 、 罚款日期 、 罚款原因 。4 “系统管理”模块:(1)员工管理:包括新员工信息的录入,密码的修改以及员工信息的删除。(2)数据备份:对现有
23、的数据库信息的保存。(3)数据恢复:对数据库信息的恢复2.1.2 模块框架图图 2-1 模块框架图日常工作借书处理还书处理缴纳罚金基本资料维护图书资料维护读者资料维护查 询图书资料查询读者资料查询借阅历史维护系统登录罚款历史维护系统管理员工管理数据备份数据恢复数据恢复图书管理系统第 12 页 共 84 页2.2 系统数据分析通过对图书管理系统的分析,可以得出该系统涉及三个实体:读者、图书、工作人员。通过对各实体数据关系的整理,我们可以画出如下 ER 图: 图 2-2 系统 E-R 图这些实体涉及的数据项有:读者:借阅证编号、姓名、身份证号、最大借书数、止借标志。图书:图书编号、图书名称、作者、
24、出版社、价格、库存量。工作人员:员工编号、员工姓名、员工性别、身份证号、登陆密码。实体之间的联系涉及的数据项有:借阅信息表:借阅证编号,图书编号 1,图书编号 2,图书编号 3,借书日期 1,借书日期 2,借书日期 3,操作员姓名。罚款信息表:借阅证编号,读者姓名,图书编号,图书名称,罚款原因,罚款金额,罚款日期,操作员姓名。还书借阅读者管理员图 书 还书第 13 页 共 84 页第三章 设计阶段3.1 概要设计3.1.1 数据库概论及 SQL、ACCESS2000 简介数据库是数据管理的最新技术,是计算机科学的重要分支。数据库,顾名思义,是存放数据的仓库。只不过这个仓库是在计算机存储设备上,
25、而且数据是按一定的格式存放的。所谓数据库是指长期储存在计算机内的、有组织的、可共享的数据集合。数据库中的数据按一定的数据模型组织、描述、和储存,具有较小的冗余度、较高的数据独立性和易扩展性,并可为各种用户共享。为了有效的管理数据库,常常需要一些数据库管理系统(DBMS)为用户提供对数据库操作的各种命令、工具及方法,包括数据库的建立和记录的输入、修改、检索、显示、删除和统计等。SQL Server 是一关系数据库,它除了支持传统关系型数据库对象和特性外,另外也支持现今关系型数据库常用的对象和存储过程、视图等。另外,我们从它的产品名称就可以知道,它支持目前关系型数据库必定要支持标准查询语言SQL(
26、Structured Query Language) 。SQL Server 另外一个重要的特点是它支持数据库复制的功能,也就是当你在数据库上执行更新时,可以将其更新结果传到远程 SQL Server 相同的数据库上,让两边数据库的数据保持同步。SQL Server 最早是由另外一个关系性数据库 Sybase 演化来的,事实上在第 14 页 共 84 页1988 年时 SQL Server 的 OS/2 版本是由 Sybase、Microsoft、Ashton-Tate 这三家公司所共同开发的,后来 NT 操作系统出现,Microsoft 将 SQL Server 移植到NT 操作系统上,三者
27、间的合作才告终止。现在 Sybase 则专著在 UNIX 操作系统上的数据库版本(称为 Sybase 数据库系统,和 Informix、Oracle 二家公司的数据库系统是在 UNIX 操作系统上最常见的数据库系统) ,而 Microsoft 则全力推广Windows NT 版本。因为在 4。21 版本以前,Microsoft 和 Sybase 皆能销售 SQL Server ,所以有时你会看到和 Microsoft SQL Server 和 Sybase SQL Server 两种类似的产品名称,事实上两者是一样的。SQL Server 在现今流行的 Client-Server 结构中是扮演
28、服务器端角色。它主要的职责是存储数据和提供一套方法来管理这些数据,并且应付来自 Client 的连接和数据存取需求。由于 SQL Server 是扮演 Server 端的角色,是数据的提供者,所以你在 SQL Server 内看不到累世 GUI 设计的功能,也就是说 SQL Server 并不提供工具让你设计一个输入或查询的操作界面,另外你也看不到和报表设计有关的工具,因为对 SQL Server 所扮演的角色而言,这不是它的职责所在。这些用户操作界面的设计工作是 Client 端的事情。通常我们将 SQL Server 或 Oracle 等数据库系统成为数据库引擎(Database Engi
29、ne) ,因为它是整个数据库应用系统中的核心,它的重要性就如同一部车子的引擎,没有它车子就无法开动。不过光有引擎还不能成为车子,你必须还要有方向盘、轮子等周边设备才可以让车子上路。同样地,当只有数据库引擎也不能构成完整的应用系统,你还要利用前端开发工具如 Visual Basic、Delphi、Power Builder 等产品开发出了用户界面才能称为完整的数据库应用系统。前端开发工具用来设计输入和查询界面,拥护通过这个界面输入数据,再由前端程序通过网络传给后段的数据库引擎将数据存储在数据库。当拥护要查询数据时,前端程序将查询命令传给后段的数据库执行,前端程序则等待接受数据结果然后再将结果显示
30、在界面上。在以前的应用程序的操作方面,用户是利用终端机或终端机模拟程序来使用数据库系统,其操作截面设计是文字导向。现今的 Client-server 结构则使用个人计算机和视窗操作系统作为前端平台,所设计出来的操作界面都是视窗化的界第 15 页 共 84 页面。SQL Server 可支持多种前端操作系统的连接。只要经过正确的设定,MS-DOS、Windows 3.11、 Windows95 和 N T Workstation 等前端平台皆可和 SQL Server 相连接。SQL Server 和前端平台连接最主要的是靠网络,所以网络设定必须正确,SQL Server 才能正常运行。在网络协
31、议方面,SQL Server 可经由TCP/IP、Netware、Name Pipe 和 NETBIOS 等通过协议和前端平台相连。至于前端应用程序则是靠标准的 ODBC 或 OLE DB 数据库驱动程序和下层的 DB-Library 网络程序驱动和 SQL Server 相连。微软开发的 ACCESS2000 是在 Windows95/98/2000 及 Windows NT 平台中应用的关系型数据库管理系统,可以通过各种数据库对象对数据进行控制和管理,不论用户创建的独立桌面数据库适用于个人、部门还是整个企业,ACCESS2000 都可以为管理数据生成易于使用的数据库,ACCESS2000
32、不仅拥有众多传统数据库管理软件所具备的功能,同时还进一步增强了与 web 页集成,能够更方便的共享跨越各种平台和不同用户级别的数据。ACCESS2000 并不需要数据库管理者具有很高的专业程序设计水平,非专业的用户完全可以利用 ACCESS2000 创建出一个功能强大的数据库系统,使用ACCESS2000 数据库管理系统除非执行复杂或专业的操作,一般情况下用户无需编写程序代码就可以完成大多数数据的管理工作。当今社会是一个信息化的社会,各行各业的数据信息都比较丰富,这决定了利用数据库管理系统管理数据是十分必要的,图书馆中进而体现的更加明显,管理员可以从成千上万本书的数据库中不费吹灰之力检索出读者
33、想要借阅的图书等等。ACCESS2000 数据库是一个面向对象,采用事件驱动机制的新型关系数据库管理系统(RDBMS)它既可以通过 ODBC 与其他数据库(Sybase、Paradox 等)相连实现数据的交换与共享,也可以与 Word 、Excel 等 Office 办公软件进行数据信息交换与共享。使用 ACCESS2000 数据库后,用户可以在单一的数据库中管理所有的信息。数据只需要在表中存储一次,用户便可以在不同的位置查看,当某一数据更新后,第 16 页 共 84 页所有显示该数据的位置都将自动更新,这样可以避免冗余存储减少了工作量和错误 ACCESS2000 数据库是由表、查询、窗体、报
34、表、数据访问页、宏以及模块七种数据对象组成,这些数据对象在数据库中有着不同的功能,这些数据库对象大部分都存储在数据库中作为 ACCESS2000 的一部分,如果要单独输出某个数据库对象,可以利用 ACCESS2000 提供的导出功能,虽然 ACCESS2000 能够利用其整合的ACCESS Visual basic 6.0 语言可视化的创建应用程序,但是很少有人利用它来开发一个数据库应用程序。3.1.2 系统数据库设计1图书信息数据表图书信息数据表的主要功能在于新书入库以及保存在库图书的主要信息和相关信息,包括:图书编号 、 图书名称 、 作者 、 出版社 、 单价以及库存量图书编号字段为主关
35、键字段,书名字段、作者字段、出版社字段、单价字段和库存量字段分别记录图书的书名、作者、出版社、图书单价和库存量的信息; 2.读者信息数据表读者信息数据表的主要功能是新读者的注册以及保存已注册的读者相关信息。它包括:借阅证编号 、 读者姓名 、 读者身份证号 、 最多借书数和止借标志 。字段名称 字段类型 字段大小 索引 必须填写BOOK_ID 文本 30 有(无重复) 是BOOK_NAME 文本 50 是CLASS 文本 20 是AUTHOR 文本 30 是PRESS 文本 50 是PRICE 数字 是STOCK 数字 是第 17 页 共 84 页读者编号字段为主关键字段,读者姓名字段、身份证
36、号字段、最大借书数字段和止借标志字段分别记录读者的借阅证编号、读者姓名、读者的身份证号、最大借书数和止借标志信息;3.员工信息数据表员工信息数据表的主要功能是新员工的注册以及保存已注册员工的相关信息。它包括:员工编号 、 员工姓名 、 员工身份证号 、 员工性别和登录密码 。员工编号字段为主关键字段,姓名字段、性别字段、身份证号字段、登录密码字段分别记录读者的员工编号、员工姓名、员工性别、员工的身份证号以及登录密码。4.借书登记信息数据表借书登记信息数据表的主要功能是进行有关借阅图书过程中信息的处理它包括:借阅证编号 、 图书编号 1、 图书编号 2、 图书编号 3、 借阅时字段名称 字段类型
37、 字段大小 索引 必须填写READER_ID 文本 30 有(无重复) 是NAME 文本 8 是ID_CARD 文本 20 是MAXNUM_CAN_BORROW 数字 长整型 是FLAG_BORROW 数字 长整型 是字段名称 字段类型 字段大小 索引 必须填写CLERK_ID 文本 30 有(无重复) 是NAME 文本 8 是ID_CARD 文本 20 是PASSWORD 文本 30 是SEX 文本 2 是第 18 页 共 84 页间 1、 借阅时间 2、 借阅时间 3和员工姓名 。5.借阅历史信息数据表借阅历史信息数据表的主要功能是对借阅历史的信息进行查询。它包括:借阅证编号 、 读者姓名
38、 、 图书编号 、 图书名称 、 借阅时间 、归还时间 借书操作员姓名 、 还书操作员姓名和备注 。6罚款信息数据表罚款信息数据表的主要功能是读者因不正常还书而被罚款的记录。它包括:借阅证编号 、 读者姓名 、 图书编号 、 图书名称 、 借阅时间 、罚款原因 罚款金额 、 罚款日期和操作员姓名 。字段名称 字段类型 字段大小 索引 必须填写READER_ID 文本 30 有(无重复) 是BOOK_ID1 文本 30 是BOOK_ID2 文本 30 是BOOK_ID3 文本 30 是BORROW_DATE1 日期 是BORROW_DATE2 日期 是BORROW_DATE3 日期 是CLERK
39、_NAME 文本 30 是文本 有(无重复) 是文本 是文本 是是日期 是日期 是文本 30 是R_CLERK_NAME 文本 是REMARK 文本 8 是第 19 页 共 84 页7.罚款历史信息数据表罚款历史信息数据表的主要功能是对某位读者罚款历史的信息进行查询。它包括: 借阅证编号 、 读者姓名 、 图书编号 、 图书名称 、 罚款原因 罚款金额 、 罚款日期和解止日期 。8.图书分类信息数据表图书分类信息数据表的主要功能是对图书进行分类。它包括:分类编号和类名字段名称 字段类型 字段大小 索引 必须填写READER_ID 文本 30 有(无重复) 是NAME 文本 30 是BOOK_I
40、D 文本 30 是BOOK_NAME 文本 30 是WHYS 文本 是AMOUNT 数字 20 是FINE_DATE 日期 是CLERK_NAME 文本 30 是字段名称 字段类型 字段大小 索引 必须填写READER_ID 文本 30 有(无重复) 是NAME 文本 30 是BOOK_ID 文本 30 是BOOK_NAME 文本 30 是WHYS 文本 是AMOUNT 数字 20 是FINE_DATE 日期 是OK_DATE 文本 30 是第 20 页 共 84 页3.2 详细设计3.2.1 数据信息准备1 “图书资料维护”模块:要进行图书资料的维护就必须有图书的相关信息:如:图书的分类、图
41、书的编号、图书的名称、图书的作者、图书出版社以及图书的库存量。新的图书,都要进行新书入库,将新书的各项信息输入图书资料维护信息数据表中,从而图书资料维护信息数据表将会更新,新书入库过程完成。在进行图书分类信息的时候,字段就相应比较少了,只需要描述某本图书在所有图书中的类型就完全可以了,这个信息将提供给工作人员进行借书登记时信息的一个依据。在图书修改信息中,每本现有的图书将会出现丢失或严重损坏,从而导致该类图书无法再进行借阅,那么就要进行删除或修改图书的库存量。2.“读者资料维护”模块:要进行读者资料的维护就必须有读者的相关信息:如:读者所使用的借阅证编号、读者的姓名、读者的身份证号以及止借标志
42、。新的读者,都要进行信息登记,将新会员的各项信息输入读者资料维护信息数据表中,从而读者资料维护信息数据表将会更新,更新后新的会员就可以借阅图书了。在进行只需要描述某本图书在所有图书中的类型就完全可以了,这个信息将提供给工作人员进行借书登记时信息的一个依据。在图书修改信息中,每本现有的图书将会出现丢失或严重损坏,从而导致该类图书无法再进行借阅,那么就要进行删除或修改图书的库存量。3.2.2 程序数据流图1系统功能流程图字段名称 字段类型 字段大小 索引 必须填写CLASS_ID 文本 30 有(无重复) 是CLASS_NAME 文本 30 是第 21 页 共 84 页调用数据库?Y/N系统主界面
43、图 3-1 系统功能流程图2 “图书资料维护”数据流图图 3-2 “图书资料维护”数据流图用户登录退出系统第 22 页 共 84 页3 “读者资料维护”数据流图图 3-3 “读者资料维护”数据流图第 23 页 共 84 页第四章 设计思想4.1 面向对象的程序设计面向对象技术是一个非常实用而强有力的软件开发方法。它具有许多特色。一是方法的唯一性,即方法是对软件开发过程所有阶段进行综合考虑而得到的。二是从生存期的一个阶段到下一个阶段的高度连续性,即在一个阶段所用到的部分与在下一个阶段所使用的部分是衔接的,所使用的技术经过生存期每一阶段后不改变。三是把面向对象分析(OOA) 、面向对象设计(OOD
44、)和面向对象程序设计(OOP)集成到生存期的相应阶段。什么是“面向对象”?对于这个问题,有许多不同的看法。Coad 和 Yourdon 给出了一个定义:“面向对象=对象+类+继承+通信” 。如果一个软件系统是使用这样 4 个概念设计和实现的,则可以认为这个软件系统是面向对象的。一个面向对象的程序的每一部分对应的是对象,计算是通过新的对象的建立和对象之间的通信来执行的。对象(object)是面向对象开发模式的基本成分。每个对象可用其一组属性和它执行的一组操作来定义。属性一般只能通过执行对象的操作改变。操作又称为方法或服务,在 C+中成为成员函数,它描述了对象执行的功能。类(class)是一组具有
45、相同数据结构和相同操作的对象的集合。类的定义包括一组数据属性和在数据上的某组合法操作。类定义可以视为一个具有类似特性与共同行为的对象的模板,可用来产生对象。在一个类中,每个对象都是类的实例(Instance) ,它们都可使用类中提供的函数。一个对象的状态则包含在它的实例变量中。继承(Inheritance)是使用已存在的(现存)定义作为基础建立新定义的技术。使用继承设计一个新的类,可以视为描述一个新的对象集合,它是现存类所描述对象集合的字集合。这个新的类可以认为是现存类的一个特化。第 24 页 共 84 页面向对象的程序设计已成为软件界主流的程序设计思想和方法。传统的过程是程序设计本质的缺陷是
46、非常不自然、不符合客观世界本身的特点以及人们分析和思考问题的习惯。面向对象的程序设计一方面是为了满足日益复杂的程序开发所提出的,另一方面为程序设计提供了一个更为合理和自然的分析和思考方式。4.2 详细设计思想4.2.1“用户登录”模块设计:登录模块是要根据用户输入的用户名和密码与数据库 Clerk 中的 Username和 Password 的比较来判断用户名和密码是否合法。这里用到在 Visual C+环境下数据库的操作。该操作的流程如下:用户在相应的控件内填写姓名和密码,通过“UpdateData(TRUE);”将控件中的数据传送给字段数据成员,然后执行下面的SQL 语句: SELECT
47、* FROM CLERKWHERE NAME=m_strName AND PASSWORD=m_strPassword;查询 Clerk 表中是否有用户名为 m_strName,并且密码为 m_strPassword 的记录。打开记录集,查询是否有符合条件的记录,如果记录集不为空,则说明有符合条件的记录,说明登录合法,否则“登录失败!” 。在用户通过了身份验证之后,就可以进入系统,进行所有的操作。第 25 页 共 84 页登录模块实现起来相对比较简单,只是用到了一个 SOL 查询语句,在编程过程中没有遇到什么困难。“用户登录”模块实现代码如下:if (m_strName.IsEmpty() /
48、*判断用户名信息是否为空*/AfxMessageBox(“请输入用户名!“);return;mSqlStr = “SELECT * FROM CLERK WHERE NAME=“;mSqlStr = mSqlStr + m_strName;mSqlStr = mSqlStr + “ AND PASSWORD=“;mSqlStr = mSqlStr + m_strPassword;mSqlStr = mSqlStr + “;if (!mrsDataSet.Open(AFX_DB_USE_DEFAULT_TYPE, mSqlStr)AfxMessageBox(“CLERK 表打开失败!“);return;/CString strSQL;/strSQL.Format(“select * from CLERK where NAME=%s AND PASSWORD=%s “,m_strName,m_strPassword);/mrsDataSet.Open(AFX_DB_USE_DEFAULT_TYPE,strSQL);if(mrsDataSet.GetRecordCount()=0)if(countAddString(“大学生“);(CComboBox *)pWnd)-AddString(“研究生“);(CComboBox *