基于JAVA的图书馆管理系统设计毕业论文.doc

上传人:小小飞 文档编号:3920884 上传时间:2019-10-10 格式:DOC 页数:62 大小:1.16MB
返回 下载 相关 举报
基于JAVA的图书馆管理系统设计毕业论文.doc_第1页
第1页 / 共62页
基于JAVA的图书馆管理系统设计毕业论文.doc_第2页
第2页 / 共62页
基于JAVA的图书馆管理系统设计毕业论文.doc_第3页
第3页 / 共62页
基于JAVA的图书馆管理系统设计毕业论文.doc_第4页
第4页 / 共62页
基于JAVA的图书馆管理系统设计毕业论文.doc_第5页
第5页 / 共62页
点击查看更多>>
资源描述

《基于JAVA的图书馆管理系统设计毕业论文.doc》由会员分享,可在线阅读,更多相关《基于JAVA的图书馆管理系统设计毕业论文.doc(62页珍藏版)》请在三一文库上搜索。

1、Xxxx 大学大学 毕业设计(论文)毕业设计(论文) 基于基于 JAVA 的图书馆管理系统设计的图书馆管理系统设计 Design of Library Management System Based on Java 学生姓名 xxxxxx 学 号 xxxxxxxxxxxxxxxxxx 专业班级 xxxxxxxxxx 指导教师 xxxxxx 2014 年年 5 月月 键入文字 键入文字 作者声明作者声明 本人声明所呈交的论文是我个人在导师指导下进行的研究工作及取得的研究 成果,除了文中特别加以标注的地方外,没有任何剽窃、抄袭、造假等违反学术 道德、学术规范的行为,也没有侵犯任何其他人或组织的科研

2、成果及专利。与我 一同工作的同志对本研究所做的任何贡献均已在论文中作了明确的说明并表示了 谢意。如本毕业设计(论文)引起的法律结果完全由本人承担。 毕业设计(论文)成果归 xxx 大学所有。 特此声明。 作者专业: xxxxxxx 作者学号: xxxxxxx 作者签名: 年 月 日 键入文字 摘摘 要要 随着网络技术的发展、计算机应用水平广泛提高,原来系统的时效性、数据 的正确性、操作的方便性上都存在不足,已影响到系统的正常使用。经过考察比 较,决定自己对图书管理系统重新设计,使系统能利用软件开发技术的成果,方 便图书的管理。 图书管理系统是典型的信息管理系统。系统介绍了图书系统的开发过程,设

3、 计中遇到的问题及解决方法以及提高当前应用程序或系统开发进度和改善工作性 能。利用其提供的各种面向对象的开发工具,首先在短时间内建立系统应用原型, 然后,对初始原型系统进行需求迭代,不断修正和改进,直到形成用户满意的可行 系统。 本次课程设计利用 JAVA 开发工具和 Mysql 数据库来开发这个图书管理系统。 该系统要解决图书管理所要解决的问题,可以满足图书管理基本要求,包括添加、 管理等功能。该系统能根据用户的需求,快捷方便的为读者提供借阅服务。 关键词:关键词: 图书管理系统;信息管理;JAVA;Mysql 键入文字 Abstract Along with networkings dev

4、elopment, the computer application levels enhancements expansion, systems effectiveness, the data accuracy, in the operation conveniences has the insufficiency originally, Has affected systems normal use. After the inspection comparison, decided that uses own strength to the literature management sy

5、stem management system redesign, enables the system to use the software development technology the achievement, convenient literature management. The literature registration management system is the typical information management system. The system introduces the literature referral systems performa

6、nce history, it meets the question in the design and the solution as well as enhance the current application procedure or the system development progress and the improvement operating performance. Each kind of object-oriented development kit which provides using it, first establishes the system appl

7、ication prototype in a short time, then, carries on the demand iteration to the initial prototype system, revises unceasingly and improves, until forms the user satisfied feasible system. This curriculum develops this literature management system management system using the JAVA development kits and

8、 Mysql. This system solves the question what the literature administration center would solve, may satisfy the literature management essential requirements, including increase, inquiry, management and so on three aspect functions. This system can act according to the user the demand, what facilitate

9、s quickly is the reader provides the service. Key Words: Literature management system; Information management; JAVA; Mysql 键入文字 目目 录录 第第 1 章章 绪论绪论.1 1.1 目前图书馆管理系统存在的问题 1 1.2 课题意义.2 1.3 本论文的研究内容.2 1.4 可行性分析 2 1.4.1 经济可行性.2 1.4.2 技术可行性.3 1.5 图书馆管理系统需求概述 3 1.5.1 系统目标.3 1.5.2 用户类和用户特性.3 第第 2 章章 开发环境及工具介

10、绍开发环境及工具介绍.5 2.1 JAVA开发环境5 2.1.1 JAVA 简介.5 2.1.2 JAVA 主要特性.5 2.1.3 JAVA 优缺点.7 2.1.4 相关技术.8 2.2MYSQL8 2.2.1 MYSQL 简介.8 2.2.2 MYSQL 特性.8 2.3MYECLIPSE 开发工具.9 第第 3 章章 系统总体结构设计及功能概述系统总体结构设计及功能概述.10 3.1 图书馆管理系统总体结构图.10 3.2 文件模块功能 10 3.3 图书管理模块功能.11 3.4 借阅管理模块功能.11 3.5 账户管理模块功能.12 3.6 查询模块功能.14 键入文字 第第 4 章

11、章 数据库设计数据库设计.16 4.1 数据库设计概述.16 4.2 数据库各表的设计.18 4.2.1 图书信息表结构设计(book 表) 18 4.2.2 管理员信息表结构设计(login 表).19 4.2.3 学生用户信息表结构设计(reader 表) .20 4.2.4 借阅卡表结构设计(student 表)21 第第 5 章章 基于基于 JAVA 的图书的图书馆馆管理系统的实现管理系统的实现23 5.1 用户登录.23 5.1.1 登录页面23 5.1.2 登录后的主页面25 5.2 退出图书管理系统.25 5.3 管理图书.26 5.3.1 图书入库26 5.3.2 图书编辑29

12、 5.3.3 图书删除32 5.4 借阅管理.35 5.4.1 图书借阅35 5.4.2 图书归还36 5.5 账户管理.38 5.5.1 密码修改39 5.5.2 读者账户管理40 5.5.3 根管理员功能43 5.6 图书查询.44 5.6.1 查询所有藏书44 5.6.2 查询已借图书45 5.6.3 图书查询46 第第 6 章章 总结与展望总结与展望.47 键入文字 参考文献参考文献.48 致谢致谢.48 键入文字 第第 1 章章 绪论绪论 随着计算机技术的飞速发展,计算机在企业管理中应用的普及,利用计算机 实现图书信息的管理势在必行。目前图书管理的借阅工作部分大多数还是手工管 理,工

13、作效率很低,并且不能及时了解图书的种类和读者们比较需求的图书等, 不能更好的适应当前读者的借阅要求。手工管理还存在这许多弊端,由于不可避 免的人为因素,造成数据的遗漏、误报。计算机信息化管理有着储存量大,速度 快等许多优点,提供给我们的处理信息及时快捷。本课题是图书馆系统的制作, 能实现图书的管理,查询,借阅,极大地提高图书管理的效率,从而解决图书管 理复杂的问题。这也是图书管理的科学化、正规化管理,与世界接轨的重要条件。 1.1 目前图书馆管理系统存在的问题目前图书馆管理系统存在的问题 1. 建立图书管理系统数据库管理图书和用户建立图书管理系统数据库管理图书和用户 因为图书馆的藏书种类多、数

14、量多,将藏书准确地分门别类,快速检索,手 工进行非常困难往往是终于查到了信息,馆中没有此书或已被别人借走。图书馆 的规模越大,这个问题越突出。 2. 借书、还书工作量大借书、还书工作量大 借书、还书频率越大,说明图书馆的作用越大,然而随之而来的大量的借书、 还书登记、实存图书的更新以及借出图书超期、遗失等的处理,其工作量之大, 往往是人工操作所难以胜任的。而且经常会出现这样那样的差错。 3. 图书统计工作难、藏书更新不能及时完成图书统计工作难、藏书更新不能及时完成 图书馆的图书应根据科学技术的发展和教学工作的需要及时添加和更新,然 而由于藏书数量及图书种类越来越多,加上自然损耗,人为破坏,使图

15、书的统计 工作难以及时完成,藏书的更新也就很难有针对性地进行,藏书的知识结构得不 到良好地控制。 键入文字 1.2 课题意义课题意义 随着计算机的广泛应用,其逐步成为现代化的标志。图书馆或者一些企业内 部,甚至是书店,在正常运行过程中总是面对大量的读者信息,书籍信息以及两 者相互作用产生的借书信息、还书信息。因此需要对读者资源、书籍资源、借书 信息、还书信息进行管理,及时了解各个环节中信息的变更,要对因此而产生的 单据进行及时的处理,为了提高图书馆或者企业内部对图书存销的自动化的管理, 能够更快速的满足读者的要求,提高各种工作的效率,现对其设计相应的系统, 以达到上述的目的1。 图书管理系统的

16、主要功能是实现图书馆图书借阅和归还的管理的自动化。围 绕这一主要功能,本系统涉及到以下核心功能:借阅管理,归还管理。除了这些 核心功能外,还包括一些基本和辅助功能,它们是:用户管理、图书管理、图书 查询。 1.3 本论文的研究内容本论文的研究内容 本课题主要研究的内容有: (1)建立图书管理系统数据库管理图书和用户; (2)完成菜单栏,有文件,管理,借阅管理,账户管理,查看等选项; (3)管理图书的增删改查,实现借书还书功能; (4)实现账户管理,密码修改功能,并能增加读者、管理员; (5)能查看所有图书,已借图书,图书查询。 1.4 可行性分析可行性分析 1.4.1 经济可行性经济可行性 由

17、于图书管理系统是作为毕业设计由我们自己开发的,在经济上的投入甚微, 系统建成之后将为今后图书管理提供很大的方便,估算新系统的开发费用和今后 键入文字 的运行、维护费用,估计新系统将获得的效益,并将费用与效益进行比较,对今 后使用十分有利2。 1.4.2 技术可行性技术可行性 技术可行性要考虑现有的技术条件是否能够顺利完成开发工作,软硬件配置 是否满足开发的需求等。本图书管理系统用的是 JAVA 开发语言,调试相对简单, 当前的计算机硬件配置也完全能满足开发的需求,因此在技术上是绝对可行的。 软件方面:由于目前单机模式相对发展成熟,故软件的开发平台成熟可行,它们 速度快、容量大、可靠性能高、价格

18、低,完全能满足系统的需求。 1.5 图书馆管理系统需求概述图书馆管理系统需求概述 1.5.1 系统目标系统目标 该系统主要建立一个基于 C/S 模式的图书馆借阅管理系统,面对当起很多小 型图书管理仍是人工管理带来的检索速度慢,效率低,借阅归还图书量大,图书统 计工作量大,藏书不能完成及时更新的问题,该系统可以对跟系统的三个用户类 型的使用实现: (1)对于读者在本系统的应用下可实现查询图书馆的藏书清单,方便的借 阅图书,续借图书,归还图书,能够查询自己的借阅图书情况; (2)对于图书馆工作人员能够实现方便的对图书进行查询,方便的进行读者 借阅情况查询,方便的进行借书还书处理等,便捷的对图书信息

19、进行添加、修改、 删除,对读者信息进行相关添加,修改等操作; (3)对于系统管理员可以对图书馆信息进行修改更新操作,对系统用户进 行添加、修改等操作。 键入文字 1.5.2 用户类和用户特性用户类和用户特性 图书借阅管理系统是一个基于 C/S 模式的对图书馆进行高效率管理的应用系 统,它的用户主要是读者和图书管理员,学生通过该系统进行图书查询进而对自己 需要的图书进行借阅及自己的借阅情况进行查询,图书管理员则通过本系统实现 对图书及读者的高效管理,除此之外,还需要一个系统管理员对不同的用户进行 权限的设置等操作3。 键入文字 第第 2 章章 开发环境及工具介绍开发环境及工具介绍 本系统采用面向

20、对象的软件开发方法,以 Java 开发环境作为主要开发工具, 使用 Mysql 作为关系数据库,配合功能强大的 SQL 查询语言实现建立关系数据 库,访问数据库,对数据库的更新,较好地实现了预定的需求功能4。 2.1 Java 开发环境开发环境 2.1.1 JAVA 简介简介 Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的 Java 程序设计语言和 Java 平台(即 JavaEE, JavaME, JavaSE)的总称。Java 自面世后就非常流行,发展迅速,对 C+ 语言形成了有力冲击。Java 技

21、术具有卓越的通用性、高效性、平台移植性和安全 性,广泛应用于个人 PC、数据中心、游戏控制台、科学超级计算机、移动电话 和互联网,同时拥有全球最大的开发者专业社群。在全球云计算和移动互联网的 产业环境下,Java 更具备了显著优势和广阔前景5。 2.1.2 JAVA 主要特性主要特性 1. Java 语言是易学的语言是易学的 Java 语言的语法与 C 语言和 C+语言很接近,使得大多数程序员很容易学习 和使用 Java。另一方面,Java 丢弃了 C+中很少使用的、很难理解的、令人迷惑 的那些特性,如操作符重载、多继承、自动的强制类型转换。特别地,Java 语言 不使用指针,而是引用。并提供

22、了自动的废料收集,使得程序员不必为内存管理 而担忧。 2. Java 语言是强制面向对象的语言是强制面向对象的 键入文字 Java 语言提供类、接口和继承等原语,为了简单起见,只支持类之间的单继 承,但支持接口之间的多继承,并支持类与接口之间的实现机制(关键字为 implements)。总之,Java 语言是一个纯的面向对象程序设计语言。 3. Java 语言是分布式的语言是分布式的 Java 语言支持 Internet 应用的开发,在基本的 Java 应用编程接口中有一个网 络应用编程接口(java net),它提供了用于网络应用编程的类库,包括 URL、URLConnection、Sock

23、et、ServerSocket 等。Java 的 RMI(远程方法激活) 机制也是开发分布式应用的重要手段。 4. Java 语言是健壮的语言是健壮的 Java 的强类型机制、异常处理、垃圾的自动收集等是 Java 程序健壮性的重要 保证。对指针的丢弃是 Java 的明智选择。Java 的安全检查机制使得 Java 更具健 壮性。 5. Java 语言是安全的语言是安全的 Java 通常被用在网络环境中,为此,Java 提供了一个安全机制以防恶意代码 的攻击。除了 Java 语言具有的许多安全特性以外,Java 对通过网络下载的类具有 一个安全防范机制(类 ClassLoader),如分配不同

24、的名字空间以防替代本地的同 名类、字节代码检查,并提供安全管理机制(类 SecurityManager)让 Java 应用设 置安全哨兵。 6. Java 语言是体系结构中立的语言是体系结构中立的 Java 程序(后缀为 java 的文件)在 Java 平台上被编译为体系结构中立的字 节码格式(后缀为 class 的文件),然后可以在实现这个 Java 平台的任何系统中 运行。这种途径适合于异构的网络环境和软件的分发。 7. Java 语言是可移植的语言是可移植的 这种可移植性来源于体系结构中立性,另外,Java 还严格规定了各个基本数 据类型的长度。Java 系统本身也具有很强的可移植性,J

25、ava 编译器是用 Java 实现 的,Java 的运行环境是用 ANSI C 实现的。 8. Java 语言是解释型的语言是解释型的 键入文字 如前所述,Java 程序在 Java 平台上被编译为字节码格式,然后可以在实现这 个 Java 平台的任何系统中运行。在运行时,Java 平台中的 Java 解释器对这些字 节码进行解释执行,执行过程中需要的类在联接阶段被载入到运行环境中。 9. Java 是性能略高的是性能略高的 与那些解释型的高级脚本语言相比,Java 的性能还是较优的。 10. Java 语言是原生支持多线程的语言是原生支持多线程的 在 Java 语言中,线程是一种特殊的对象,

26、它必须由 Thread 类或其子(孙) 类来创建。通常有两种方法来创建线程:其一,使用型构为 Thread(Runnable)的 构造子将一个实现了 Runnable 接口的对象包装成一个线程;其二,从 Thread 类 派生出子类并重写 run 方法,使用该子类创建的对象即为线程。值得注意的是 Thread 类已经实现了 Runnable 接口,因此,任何一个线程均有它的 run 方法,而 run 方法中包含了线程所要运行的代码。线程的活动由一组方法来控制。Java 语 言支持多个线程的同时执行,并提供多线程之间的同步机制(关键字为 synchronized)。 11. Java 语言是动态

27、的语言是动态的 Java 语言的设计目标之一是适应于动态变化的环境。Java 程序需要的类能够 动态地被载入到运行环境,也可以通过网络来载入所需要的类。这也有利于软件 的升级。另外,Java 中的类有一个运行时刻的表示,能进行运行时刻的类型检查。 Java 语言的优良特性使得 Java 应用具有无比的健壮性和可靠性,这也减少了 应用系统的维护费用。Java 对对象技术的全面支持和 Java 平台内嵌的 API 能缩短 应用系统的开发时间并降低成本。Java 的编译一次,到处可运行的特性使得它能 够提供一个随处可用的开放结构和在多平台之间传递信息的低成本方式。特别是 Java 企业应用编程接口(

28、Java Enterprise APIs)为企业计算及电子商务应用系统提 供了有关技术和丰富的类库6。 2.1.3 JAVA 优缺点优缺点 优势: 键入文字 Java 编程语言是个简单、面向对象、分布式、解释性、健壮、安全与系统无 关、可移植、高性能、多线程和动态的语言。 Java 是功能完善的通用程序设计语言,可以用来开发可靠的、要求严格的应 用程序。Java 适合团队开发,软件工程可以相对做到规范。由于 Java 语言本身的 极其严格语法的特点,Java 语言无法写出结构混乱的程序。这将强迫程序员的代 码软件结构的规范性。这是一个很难比拟的优势。 缺点: j2ee 的架构很完美,第一版软件

29、可以做满意,但是很不适合互联网模式的持 续不断修改。互联网软件工程管理上的不足,持续的修修补补导致架构的破坏。 2.1.4 相关技术相关技术 JDBC(Java Database Connectivity)提供连接各种关系数据库的统一接口, 作为数据源,可以为多种关系数据库提供统一访问,它由一组用 Java 语言编写的 类和接口组成7。JDBC 为工具/数据库开发人员提供了一个标准的 API,据此可 以构建更高级的工具和接口,使数据库开发人员能够用纯 Java API 编写数据库应 用程序,同时,JDBC 也是个商标名。 2.2 MYSQL 2.2.1 MYSQL 简介简介 MySQL 是一个

30、开放源码的小型关联式数据库管理系统,开发者为瑞典 Mysql AB 公司。MySQL 被广泛地应用在 Internet 上的中小型网站中。由于其体积小、 速度快、总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低 网站总体拥有成本而选择了 MySQL 作为网站数据库8。 2.2.2 MYSQL 特性特性 (1)使用 C 和 C+编写,并使用了多种编译器进行测试,保证源代码的可 移植性; 键入文字 (2)支持 AIX、FreeBSD、HP-UX、Linux、Mac OS、NovellNetware、OpenBSD、OS/2 Wrap、Solaris、Windows 等多种操作系统;

31、(3)为多种编程语言提供了 API。这些编程语言包括 C、C+、Python、Java、Perl、PHP、Eiffel、Ruby 和 Tcl 等; (4)支持多线程,充分利用 CPU 资源; (5)优化的 SQL 查询算法,有效地提高查询速度; (6)既能够作为一个单独的应用程序应用在客户端服务器网络环境中,也 能够作为一个库而嵌入到其他的软件中; (7)提供多语言支持,常见的编码如中文的 GB 2312、BIG5,日文的 Shift_JIS 等都可以用作数据表名和数据列名; (8)提供 TCP/IP、ODBC 和 JDBC 等多种数据库连接途径; (9)提供用于管理、检查、优化数据库操作的管

32、理工具; (10)支持大型的数据库,可以处理拥有上千万条记录的大型数据库; (11)支持多种存储引擎; (12)Mysql 是开源的,所以你不需要支付额外的费用; (13)MySQL 使用标准的 SQL 数据语言形式; (14)Mysql 对 PHP 有很好的支持,PHP 是目前最流行的 Web 开发语言; (15)Mysql 是可以定制的,采用了 GPL 协议,你可以修改源码来开发自己 的 Mysql 系统。 2.3 MyEclipse 开发工具开发工具 MyEclipse 企业级工作平台(MyEclipseEnterprise Workbench ,简称 MyEclipse)是对 Ecli

33、pseIDE 的扩展,利用它我们可以在数据库和 JavaEE 的开发、 发布以及应用程序服务器的整合方面极大的提高工作效率。它是功能丰富的 JavaEE 集成开发环境,包括了完备的编码、调试、测试和发布功能,完整支持 HTML,Struts,JSP,CSS,Javascript,Spring,SQL,Hibernate。 MyEclipse 是一个十分优秀的用于开发 Java, J2EE 的 Eclipse 插件集合, 键入文字 MyEclipse 的功能非常强大,支持也十分广泛,尤其是对各种开源产品的支持十 分不错。MyEclipse 目前支持 Java Servlet,AJAX,JSP,J

34、SF,Struts,Spring,Hibernate,EJB3,JDBC 数据库链接 工具等多项功能。可以说 MyEclipse 是几乎囊括了目前所有主流开源产品的专属 eclipse 开发工具。 第第 3 章章 系统总体结构设计及功能概述系统总体结构设计及功能概述 3.1 图书馆管理系统总体结构图图书馆管理系统总体结构图 绘制系统结构图的过程,实际上就是对系统功能模块进行分解设计的过程, 即合理地将数据流程图转变为所需要的系统结构图。 系统结构图将会使读者和用户能直观的了解系统的结构模式,理解系统的各 个功能的结构,能很好地方便用户使用和理解整个系统。 本系统的结构如图 3.1 所示。 图图

35、 3.1 系统结构图系统结构图 根据需求分析的结果,按照“低耦合、高内聚”的原则,本系统将划分为以下 主要功能模块:管理员管理功能模块,学生用户管理功能模块,图书管理功能模 块,图书借阅归还功能模块,图书查询功能模块。 键入文字 3.2 文件模块功能文件模块功能 该模块的作用是安全退出图书管理系统。 3.3 图书管理模块功能图书管理模块功能 该模块主要有图书入库,图书编辑和图书删除三个功能,其描述如表 3.1 所 示。 表表 3.1 图书信息管理描述图书信息管理描述 图书信息管理 功能描述对图书进行基本操作和信息管理 访问的数据库表图书类型表:book 进行的操作 添加、修改、删除图书,对图书

36、的书号、书名、 单价、作者、出版社等基本信息进行管理 产生的结果 对图书基本操作管理,对不同图书参数进行各自信 息的设置管理 结果存储位置或输 出 结果存储在图书类型表(book)中,结果在图书查询 页面输出 3.4 借阅管理模块功能借阅管理模块功能 该模块主要包含借书,还书两个子模块。 借书的描述如表 3.2 所示。 键入文字 表表 3.2 图书借阅描述图书借阅描述 图书借阅管理 功能描述对读者借阅图书进行基本操作和信息管理 访问的数据库表 图书信息表:book 学生信息表:student 读者信息表:reader 进行的操作对读者借阅图书进行管理 产生的结果读者借阅成功,系统对借阅信息进行

37、记录 结果存储位置或输 出 结果存储在图书信息表(book)中,结果在图书 借阅查询页面输出 还书的描述如表 3.3 所示。 表表 3.3 图书归还描述图书归还描述 图书归还管理 功能描述对读者归还图书进行基本操作和信息管理 访问的数据库表 图书信息表:book 学生信息表:student 读者信息表:reader 进行的操作对读者借阅图书进行管理 产生的结果读者借阅成功,系统对借阅信息进行记录 结果存储位置或输 出 结果存储在图书归还表(book)中 键入文字 3.5 账户管理模块功能账户管理模块功能 该模块主要包含密码修改,读者账户管理,根管理员功能三个子模块。 密码修改的描述如表 3.4

38、 所示。 表表 3.4 密码修改描述密码修改描述 密码修改 功能描述对已登录系统的账户进行密码修改操作 访问的数据库表管理员信息表:login 进行的操作修改本账户密码 产生的结果修改成功,旧密码将被新密码替换 结果存储位置或输 出 结果存储在管理员信息表(login)中 读者账户管理的描述如表 3.5 所示。 表表 3.5 读者账户管理描述读者账户管理描述 读者账户管理 功能描述对读者账号进行基本操作和信息管理 访问的数据库表读者信息表: reader 进行的操作增加、删除读者账号 产生的结果 操作成功, 系统对读者账号信息进行记录或修 改 结果存储位置或输 出 结果存储在读者信息表(rea

39、der)中 根管理员功能的描述如表 3.6 所示。 键入文字 表表 3.6 根管理员功能描述根管理员功能描述 根管理员功能 功能描述对管理员账号进行基本操作和信息管理 访问的数据库表管理员信息表:login 进行的操作增加、删除管理员账号 产生的结果 操作成功, 系统对管理员账号信息进行记录或 修改 结果存储位置或输 出 结果存储在管理员信息表(login)中 3.6 查询模块功能查询模块功能 该模块主要包含所有藏书,已借图书,图书查询三个子模块。 所有藏书的描述如表 3.7 所示。 表表 3.7 所有藏书描述所有藏书描述 所有藏书 功能描述对图书馆藏书进行查询 访问的数据库表图书信息表:bo

40、ok 进行的操作查询图书馆所有藏书 产生的结果操作成功, 系统对所有图书信息进行显示 结果存储位置或输结果存储在图书信息表(book)中 键入文字 出 已借图书的描述如表 3.8 所示。 表表 3.8 已借图书描述已借图书描述 已借图书 功能描述对已借图书进行查询 访问的数据库表图书信息表:book 进行的操作查询已借图书 产生的结果操作成功, 系统对已借图书信息进行显示 结果存储位置或输 出 结果存储在图书信息表(book)中 图书查询的描述如表 3.9 所示。 表表 3.9 图书查询描述图书查询描述 图书查询 功能描述对图书名进行模糊查询筛选出需要的图书 访问的数据库表图书信息表:book

41、 进行的操作按图书名查询所需图书 产生的结果操作成功, 系统对筛选图书信息进行显示 结果存储位置或输 出 结果存储在图书信息表(book)中 键入文字 第第 4 章章 数据库设计数据库设计 4.1 数据库设计概述数据库设计概述 数据库是整个系统的基石,数据库的设计优劣直接影响到整个系统的设计成 败,本节对数据库的设计进行专门阐述。 数据库是数据管理的最新技术。十多年来数据库管理系统已从专用的应用程 序发展成为通用的系统软件。由于数据库具有数据结构化,最低冗余度,较高的 程序与数据独立性,易于扩充,易于编制应用程序等优点,较大的信息系统都是 建立在数据库设计之上的。因此不仅大型计算机及中小型计算

42、机,甚至微型机都 配有数据库管理系统9。 数据库系统的出现使信息系统从以加工数据的程序为中心转向围绕共享的数 据库为中心的新阶段。这样既便于数据的集中管理,又有利于应用程序的研制和 维护,提高了数据的利用性和相容性,提高了决策的可靠性。目前,数据库已经 成为现代信息系统不可分割的重要组成部分。数据库技术也是计算机领域中发展 最快的技术之一。 数据库设计是把现实世界的实体模型与需求转换成数据库的模型的过程,它 是建立数据库应用系统的核心问题。数据库及其应用的性能都建立在良好的数据 库设计的基础之上,数据库的数据是一切操作的基础,如果数据库设计不好,那 么其它一切用于提高数据库性能的方法收效都是有

43、限的。数据库设计的关键是如 何使设计的数据库能合理地存储用户的数据,方便用户进行数据处理。 设计数据库必须遵循一定的规则,在关系型数据库中,这种规则就是范式, 范式是符合某一种级别的关系模式的集合。一般人们设计数据库遵循第三范式。 即:数据库表中不包含已在其他表中包含的非主关键字信息。采用范式减少了数 据冗余,节约了存储空间,同时加快了增、删、改的速度10。 整个系统所包括的信息有图书信息、用户信息、管理员信息、图书状态信息。 可将这些信息抽象为下列系统所需要的数据项和数据结构: (1)图书信息(图书号,图书名,单价,作者,出版社,入库时间,借阅 者); 键入文字 (2)管理员信息(用户名,密

44、码); (3)学生信息(用户名,密码); (4)借阅卡信息(卡号,密码)。 注:带下划线表示主键。 在这里使用 E-R 图描述了图书借阅管理系统的数据模型。图书借阅管理系统 E-R 图描述了该系统所涉及到的实体以及他们之间的关系。设计规划出的实体有:图 书信息实体、学生信息实体、管理员信息实体。具体结构如图 4.1 所示。 图图 4.1 数据库数据库E-R 图图 权限 学生 图书 管理员 用户名 出版社 用户名 卡号 图书名 图书号 单价 作者 入库时间 借阅者 办理 借书 键入文字 4.2 数据库各表的设计数据库各表的设计 4.2.1 图书信息表结构设计图书信息表结构设计(book 表表)

45、图书信息表主要用于存储图书馆中所藏图书的相关信息,其中的相关信息是 在图书入库时由图书管理员进行添加完善,此表主要用于读者和图书管理员对馆 中图书的查询,系统用户根据图书的某个属性进行查询,便可得知图书的其他相 关信息。 表的具体结构如表 4.1 所示。 表表 4. 1 图书图书信息信息表结构表结构 字段名称字段名称数据类型数据类型字段长度字段长度可否为空可否为空说明说明 bookNumvarchar45No(Key)图书号 bookNamevarchar45Yes图书名 pricevarchar45Yes单价 authorvarchar45Yes作者 pressvarchar45Yes出版社

46、 timeInvarchar45Yes入库时间 borrowervarchar45Yes借阅者 表 4.1 在数据库中对应的视图如图 4.2 所示。 键入文字 图图 4.2 数据库数据库 book 表表 DDL 信息:信息: CREATE TABLE book ( bookNum varchar(45) default NULL, bookName varchar(45) NOT NULL default , price varchar(45) default NULL, author varchar(45) default NULL, press varchar(45) default NU

47、LL, timeIn timestamp NULL default NULL, borrower varchar(255) default NULL, PRIMARY KEY (bookName) ) ENGINE=InnoDB DEFAULT CHARSET=utf811 4.2.2 管理员信息表结构设计(管理员信息表结构设计(login 表表) 此表的设计是为了储存管理员信息,根据管理需求的不同对其权限进行的设 置,用于规定不同类型管理员的管理权限。 表的具体结构设计如表 4.2 所示。 键入文字 表表 4.2 用户信息表结构用户信息表结构 字段名称字段名称数据类型数据类型字段长度字段长度

48、可否为空可否为空说明说明 unamevarchar45No(Key)用户名 passwdvarchar45Yes密码 表 4.2 在数据库中对应的视图如图 4.3 所示。 图图 4.3 数据库数据库 login 表表 DDL 信息:信息: CREATE TABLE login ( uname varchar(45) NOT NULL default , passwd varchar(45) default NULL, PRIMARY KEY (uname) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 4.2.3 学生用户信息表结构设计学生用户信息表结构设计(rea

49、der 表表) 学生用户信息表的设计是为了图书馆管理员对学生进行管理,其中学生 ReadId号码都是唯一的,是学生在借阅图书时需要输入对读者身份进行识别的信 息。 键入文字 表的具体结构设计如表 4.3 所示。 表表 4.3 读者信息表结构读者信息表结构 字段名称字段名称数据类型数据类型字段长度字段长度可否为空可否为空说明说明 ReadIdvarchar45No(Key)用户名 readPasswdvarchar45Yes密码 表 4.3 在数据库中对应的视图如图 4.4 所示。 图图 4. 4 数据库数据库 reader 表表 DDL 信息:信息: CREATE TABLE reader ( readerID varchar(45) NOT NULL default , readPasswd varchar(45) default NULL, PRIMARY KEY (readerID) ) E

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 其他


经营许可证编号:宁ICP备18001539号-1