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

上传人:痛*** 文档编号:100078499 上传时间:2022-06-02 格式:DOC 页数:63 大小:1.08MB
收藏 版权申诉 举报 下载
基于JAVA的图书馆管理系统设计毕业设计论文_第1页
第1页 / 共63页
基于JAVA的图书馆管理系统设计毕业设计论文_第2页
第2页 / 共63页
基于JAVA的图书馆管理系统设计毕业设计论文_第3页
第3页 / 共63页
资源描述:

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

1、 Xxxx大学毕业设计论文基于JAVA的图书馆管理系统设计Design of Library Management System Based on Java学生xxx学 号xxxxxxxxx专业班级 xxxxxxxxxx指导教师 xxx2014年5月55 / 63作者声明本人声明所呈交的论文是我个人在导师指导下进展的研究工作及取得的研究成果,除了文中特别加以标注的地方外,没有任何剽窃、抄袭、造假等违反学术道德、学术规的行为,也没有侵犯任何其他人或组织的科研成果及专利。与我一同工作的同志对本研究所做的任何奉献均已在论文中作了明确的说明并表示了意。如本毕业设计论文引起的法律结果完全由本人承当。毕业

2、设计论文成果归xxx大学所有。特此声明。作者专业: xxxxxxx 作者学号:xxxxxxx 作者签名:年月日摘 要随着网络技术的开展、计算机应用水平广泛提高,原来系统的时效性、数据的正确性、操作的方便性上都存在缺乏,已影响到系统的正常使用。经过考察比较,决定自己对图书管理系统重新设计,使系统能利用软件开发技术的成果,方便图书的管理。图书管理系统是典型的信息管理系统。系统介绍了图书系统的开发过程,设计中遇到的问题及解决方法以及提高当前应用程序或系统开发进度和改善工作性能。利用其提供的各种面向对象的开发工具,首先在短时间建立系统应用原型,然后,对初始原型系统进展需求迭代,不断修正和改良,直到形成

3、用户满意的可行系统。本次课程设计利用JAVA开发工具和Mysql数据库来开发这个图书管理系统。该系统要解决图书管理所要解决的问题,可以满足图书管理根本要求,包括添加、管理等功能。该系统能根据用户的需求,快捷方便的为读者提供借阅效劳。关键词:图书管理系统;信息管理;JAVA;MysqlAbstractAlong with networkings development, the puter application levels enhancements expansion, systems effectiveness, the data accuracy, in the operation co

4、nveniences has the insufficiency originally, Has affected systems normal use. After the inspection parison, decided that uses own strength to the literature management system management system redesign, enables the system to use the software development technology the achievement, convenient literat

5、ure management.The literature registration management system is the typical information management system. The system introduces the literature referral systems performance history, it meets the question in the design and the solution as well as enhance the current application procedure or the syste

6、m development progress and the improvement operating performance. Each kind of object-oriented development kit which provides using it, first establishes the system application prototype in a short time, then, carries on the demand iteration to the initial prototype system, revises unceasingly and i

7、mproves, until forms the user satisfied feasible system.This curriculum develops this literature management system management system using the JAVA development kits and Mysql. This system solves the question what the literature administration center would solve, may satisfy the literature management

8、 essential requirements, including increase, inquiry, management and so on three aspect functions. This system can act according to the user the demand, what facilitates quickly is the reader provides the service.Key Words: Literature management system;Information management;JAVA;Mysql目 录第1章绪论11.1 目

9、前图书馆管理系统存在的问题11.2课题意义21.3本论文的研究容21.4 可行性分析21.4.1 经济可行性21.4.2 技术可行性31.5 图书馆管理系统需求概述31.5.1 系统目标31.5.2 用户类和用户特性3第2章开发环境及工具介绍52.1 Java开发环境52.1.1 JAVA简介52.1.2 JAVA主要特性52.1.3 JAVA优缺点72.1.4 相关技术82.2MYSQL82.2.1 MYSQL简介82.2.2 MYSQL特性82.3MYECLIPSE开发工具9第3章系统总体构造设计及功能概述103.1图书馆管理系统总体构造图103.2 文件模块功能103.3图书管理模块功能

10、113.4借阅管理模块功能113.5账户管理模块功能123.6查询模块功能14第4章数据库设计164.1数据库设计概述164.2数据库各表的设计184.2.1图书信息表构造设计(book表)184.2.2 管理员信息表构造设计(login表)194.2.3 学生用户信息表构造设计(reader表)204.2.4 借阅卡表构造设计(student表)21第5章基于JAVA的图书馆管理系统的实现235.1用户登录235.1.1登录页面235.1.2登录后的主页面255.2退出图书管理系统255.3管理图书265.3.1图书入库265.3.2图书编辑295.3.3图书删除325.4借阅管理355.4

11、.1图书借阅355.4.2图书归还365.5账户管理385.5.1密码修改395.5.2读者账户管理405.5.3根管理员功能435.6图书查询445.6.1查询所有藏书445.6.2查询已借图书455.6.3图书查询46第6章总结与展望47参考文献48致48第1章 绪论随着计算机技术的飞速开展,计算机在企业管理中应用的普及,利用计算机实现图书信息的管理势在必行。目前图书管理的借阅工作局部大多数还是手工管理,工作效率很低,并且不能及时了解图书的种类和读者们比较需求的图书等,不能更好的适应当前读者的借阅要求。手工管理还存在这许多弊端,由于不可防止的人为因素,造成数据的遗漏、误报。计算机信息化管理

12、有着储存量大,速度快等许多优点,提供应我们的处理信息及时快捷。本课题是图书馆系统的制作,能实现图书的管理,查询,借阅,极提高图书管理的效率,从而解决图书管理复杂的问题。这也是图书管理的科学化、正规化管理,与世界接轨的重要条件。1.1 目前图书馆管理系统存在的问题1. 建立图书管理系统数据库管理图书和用户因为图书馆的藏书种类多、数量多,将藏书准确地分门别类,快速检索,手工进展非常困难往往是终于查到了信息,馆中没有此书或已被别人借走。图书馆的规模越大,这个问题越突出。2. 借书、还书工作量大借书、还书频率越大,说明图书馆的作用越大,然而随之而来的大量的借书、还书登记、实存图书的更新以及借出图书超期

13、、遗失等的处理,其工作量之大,往往是人工操作所难以胜任的。而且经常会出现这样那样的过失。3. 图书统计工作难、藏书更新不能及时完成图书馆的图书应根据科学技术的开展和教学工作的需要及时添加和更新,然而由于藏书数量及图书种类越来越多,加上自然损耗,人为破坏,使图书的统计工作难以及时完成,藏书的更新也就很难有针对性地进展,藏书的知识构造得不到良好地控制。1.2课题意义随着计算机的广泛应用,其逐步成为现代化的标志。图书馆或者一些企业部,甚至是书店,在正常运行过程中总是面对大量的读者信息,书籍信息以及两者相互作用产生的借书信息、还书信息。因此需要对读者资源、书籍资源、借书信息、还书信息进展管理,及时了解

14、各个环节息的变更,要对因此而产生的单据进展及时的处理,为了提高图书馆或者企业部对图书存销的自动化的管理,能够更快速的满足读者的要求,提高各种工作的效率,现对其设计相应的系统,以到达上述的目的1。图书管理系统的主要功能是实现图书馆图书借阅和归还的管理的自动化。围绕这一主要功能,本系统涉及到以下核心功能:借阅管理,归还管理。除了这些核心功能外,还包括一些根本和辅助功能,它们是:用户管理、图书管理、图书查询。1.3本论文的研究容本课题主要研究的容有:1建立图书管理系统数据库管理图书和用户;2完成菜单栏,有文件,管理,借阅管理,账户管理,查看等选项;3管理图书的增删改查,实现借书还书功能;4实现账户管

15、理,密码修改功能,并能增加读者、管理员;5能查看所有图书,已借图书,图书查询。1.4 可行性分析1.4.1 经济可行性由于图书管理系统是作为毕业设计由我们自己开发的,在经济上的投入甚微,系统建成之后将为今后图书管理提供很大的方便,估算新系统的开发费用和今后的运行、维护费用,估计新系统将获得的效益,并将费用与效益进展比较,对今后使用十分有利2。1.4.2 技术可行性技术可行性要考虑现有的技术条件是否能够顺利完成开发工作,软硬件配置是否满足开发的需求等。本图书管理系统用的是JAVA开发语言,调试相对简单,当前的计算机硬件配置也完全能满足开发的需求,因此在技术上是绝对可行的。软件方面:由于目前单机模

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

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

18、关系数据库,配合功能强大的SQL查询语言实现建立关系数据库,访问数据库,对数据库的更新,较好地实现了预定的需求功能4。2.1 Java开发环境2.1.1 JAVA简介Java是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由Sun Microsystems公司于1995年5月推出的Java程序设计语言和Java平台即JavaEE, JavaME, JavaSE的总称。Java自面世后就非常流行,开展迅速,对C+语言形成了有力冲击。Java 技术具有卓越的通用性、高效性、平台移植性和平安性,广泛应用于个人PC、数据中心、游戏控制台、科学超级计算机、移动和互联网,同时拥有全球最大的开发者专

19、业社群。在全球云计算和移动互联网的产业环境下,Java更具备了显著优势和广阔前景5。2.1.2 JAVA主要特性1. Java语言是易学的Java语言的语法与C语言和C+语言很接近,使得大多数程序员很容易学习和使用Java。另一方面,Java丢弃了C+中很少使用的、很难理解的、令人迷惑的那些特性,如操作符重载、多继承、自动的强制类型转换。特别地,Java语言不使用指针,而是引用。并提供了自动的废料收集,使得程序员不必为存管理而担忧。2. Java语言是强制面向对象的Java语言提供类、接口和继承等原语,为了简单起见,只支持类之间的单继承,但支持接口之间的多继承,并支持类与接口之间的实现机制关键

20、字为implements。总之,Java语言是一个纯的面向对象程序设计语言。3. Java语言是分布式的Java语言支持Internet应用的开发,在根本的Java应用编程接口中有一个网络应用编程接口java net,它提供了用于网络应用编程的类库,包括URL、URLConnection、Socket、ServerSocket等。Java的RMI远程方法激活机制也是开发分布式应用的重要手段。4. Java语言是强健的Java的强类型机制、异常处理、垃圾的自动收集等是Java程序强健性的重要保证。对指针的丢弃是Java的明智选择。Java的平安检查机制使得Java更具强健性。5. Java语言是

21、平安的Java通常被用在网络环境中,为此,Java提供了一个平安机制以防恶意代码的攻击。除了Java语言具有的许多平安特性以外,Java对通过网络下载的类具有一个平安防机制类ClassLoader,如分配不同的名字空间以防替代本地的同名类、字节代码检查,并提供平安管理机制类SecurityManager让Java应用设置平安哨兵。6. Java语言是体系构造中立的Java程序后缀为java的文件在Java平台上被编译为体系构造中立的字节码格式后缀为class的文件,然后可以在实现这个Java平台的任何系统中运行。这种途径适合于异构的网络环境和软件的分发。7. Java语言是可移植的这种可移植性

22、来源于体系构造中立性,另外,Java还严格规定了各个根本数据类型的长度。Java系统本身也具有很强的可移植性,Java编译器是用Java实现的,Java的运行环境是用ANSI C实现的。8. Java语言是解释型的如前所述,Java程序在Java平台上被编译为字节码格式,然后可以在实现这个Java平台的任何系统中运行。在运行时,Java平台中的Java解释器对这些字节码进展解释执行,执行过程中需要的类在联接阶段被载入到运行环境中。9. Java是性能略高的与那些解释型的高级脚本语言相比,Java的性能还是较优的。10. Java语言是原生支持多线程的在Java语言中,线程是一种特殊的对象,它必

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

24、需要的类能够动态地被载入到运行环境,也可以通过网络来载入所需要的类。这也有利于软件的升级。另外,Java中的类有一个运行时刻的表示,能进展运行时刻的类型检查。Java语言的优良特性使得Java应用具有无比的强健性和可靠性,这也减少了应用系统的维护费用。Java对对象技术的全面支持和Java平台嵌的API能缩短应用系统的开发时间并降低本钱。Java的编译一次,到处可运行的特性使得它能够提供一个随处可用的开放构造和在多平台之间传递信息的低本钱方式。特别是Java企业应用编程接口Java Enterprise APIs为企业计算及电子商务应用系统提供了有关技术和丰富的类库6。2.1.3 JAVA优缺

25、点优势:Java 编程语言是个简单、面向对象、分布式、解释性、强健、平安与系统无关、可移植、高性能、多线程和动态的语言。Java是功能完善的通用程序设计语言,可以用来开发可靠的、要求严格的应用程序。Java适合团队开发,软件工程可以相对做到规。由于Java语言本身的极其严格语法的特点,Java语言无法写出构造混乱的程序。这将强迫程序员的代码软件构造的规性。这是一个很难比较的优势。缺点:j2ee的架构很完美,第一版软件可以做满意,但是很不适合互联网模式的持续不断修改。互联网软件工程管理上的缺乏,持续的修修补补导致架构的破坏。2.1.4 相关技术JDBCJava Database Connecti

26、vity提供连接各种关系数据库的统一接口,作为数据源,可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口组成7。JDBC为工具/数据库开发人员提供了一个标准的API,据此可以构建更高级的工具和接口,使数据库开发人员能够用纯Java API 编写数据库应用程序,同时,JDBC也是个商标名。2.2 MYSQL2.2.1 MYSQL简介MySQL是一个开放源码的小型关联式数据库管理系统,开发者为瑞典Mysql AB公司。MySQL被广泛地应用在Internet上的中小型中。由于其体积小、速度快、总体拥有本钱低,尤其是开放源码这一特点,许多中小型为了降低总体拥有本钱而选择了MySQ

27、L作为数据库8。 2.2.2 MYSQL特性1使用C和C+编写,并使用了多种编译器进展测试,保证源代码的可移植性;2支持AIX、FreeBSD、HP-UX、Linux、Mac OS、NovellNetware、OpenBSD、OS/2 Wrap、Solaris、Windows等多种操作系统;3为多种编程语言提供了API。这些编程语言包括C、C+、Python、Java、Perl、PHP、Eiffel、Ruby和Tcl等;4支持多线程,充分利用CPU资源;5优化的SQL查询算法,有效地提高查询速度;6既能够作为一个单独的应用程序应用在客户端效劳器网络环境中,也能够作为一个库而嵌入到其他的软件中;

28、7提供多语言支持,常见的编码如中文的GB 2312、BIG5,日文的Shift_JIS等都可以用作数据表名和数据列名;8提供TCP/IP、ODBC和JDBC等多种数据库连接途径;9提供用于管理、检查、优化数据库操作的管理工具;10支持大型的数据库,可以处理拥有上千万条记录的大型数据库;11支持多种存储引擎;12Mysql是开源的,所以你不需要支付额外的费用;13MySQL使用标准的SQL数据语言形式;14Mysql对PHP有很好的支持,PHP是目前最流行的Web开发语言;15Mysql是可以定制的,采用了GPL协议,你可以修改源码来开发自己的Mysql系统。 2.3 MyEclipse开发工具

29、MyEclipse企业级工作平台MyEclipseEnterprise Workbench ,简称MyEclipse是对EclipseIDE的扩展,利用它我们可以在数据库和JavaEE的开发、发布以及应用程序效劳器的整合方面极大的提高工作效率。它是功能丰富的JavaEE集成开发环境,包括了完备的编码、调试、测试和发布功能,完整支持HTML,Struts,JSP,CSS,Javascript,Spring,SQL,Hibernate。MyEclipse 是一个十分优秀的用于开发Java, J2EE的 Eclipse 插件集合,MyEclipse的功能非常强大,支持也十分广泛,尤其是对各种开源产品

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

31、根据需求分析的结果,按照“低耦合、高聚的原那么,本系统将划分为以下主要功能模块:管理员管理功能模块,学生用户管理功能模块,图书管理功能模块,图书借阅归还功能模块,图书查询功能模块。3.2 文件模块功能该模块的作用是平安退出图书管理系统。3.3图书管理模块功能该模块主要有图书入库,图书编辑和图书删除三个功能,其描述如表3.1所示。表3.1 图书信息管理描述图书信息管理功能描述对图书进展根本操作和信息管理访问的数据库表图书类型表:book进展的操作添加、修改、删除图书,对图书的书号、书名、单价、作者、等根本信息进展管理产生的结果对图书根本操作管理,对不同图书参数进展各自信息的设置管理结果存储位置或

32、输出结果存储在图书类型表(book)中,结果在图书查询页面输出3.4借阅管理模块功能该模块主要包含借书,还书两个子模块。借书的描述如表3.2所示。表3.2 图书借阅描述图书借阅管理功能描述对读者借阅图书进展根本操作和信息管理访问的数据库表图书信息表:book学生信息表:student读者信息表:reader进展的操作对读者借阅图书进展管理产生的结果读者借阅成功,系统对借阅信息进展记录结果存储位置或输出结果存储在图书信息表(book)中,结果在图书借阅查询页面输出还书的描述如表3.3所示。表3.3 图书归还描述图书归还管理功能描述对读者归还图书进展根本操作和信息管理访问的数据库表图书信息表:bo

33、ok学生信息表:student读者信息表:reader进展的操作对读者借阅图书进展管理产生的结果读者借阅成功,系统对借阅信息进展记录结果存储位置或输出结果存储在图书归还表(book)中3.5账户管理模块功能该模块主要包含密码修改,读者账户管理,根管理员功能三个子模块。密码修改的描述如表3.4所示。表3.4 密码修改描述密码修改功能描述对已登录系统的账户进展密码修改操作访问的数据库表管理员信息表:login进展的操作修改本账户密码产生的结果修改成功,旧密码将被新密码替换结果存储位置或输出结果存储在管理员信息表(login)中读者账户管理的描述如表3.5所示。表3.5 读者账户管理描述读者账户管理

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

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

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

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

38、数据处理。设计数据库必须遵循一定的规那么,在关系型数据库中,这种规那么就是式,式是符合某一种级别的关系模式的集合。一般人们设计数据库遵循第三式。即:数据库表中不包含已在其他表中包含的非主关键字信息。采用式减少了数据冗余,节约了存储空间,同时加快了增、删、改的速度10。整个系统所包括的信息有图书信息、用户信息、管理员信息、图书状态信息。可将这些信息抽象为以下系统所需要的数据项和数据构造:1图书信息图书号,图书名,单价,作者,入库时间,借阅者;2管理员信息用户名,密码;3学生信息用户名,密码;4借阅卡信息卡号,密码。注:带下划线表示主键。在这里使用E-R图描述了图书借阅管理系统的数据模型。图书借阅

39、管理系统E-R图描述了该系统所涉及到的实体以及他们之间的关系。设计规划出的实体有:图书信息实体、学生信息实体、管理员信息实体。具体构造如图4.1所示。借阅者用户名入库时间图书号 学生借书办理 图书图书名单价作者卡号用户名管理员权限图4.1 数据库E-R图4.2数据库各表的设计4.2.1图书信息表构造设计(book表)图书信息表主要用于存储图书馆中所藏图书的相关信息,其中的相关信息是在图书入库时由图书管理员进展添加完善,此表主要用于读者和图书管理员对馆中图书的查询,系统用户根据图书的某个属性进展查询,便可得知图书的其他相关信息。表的具体构造如表4.1所示。表4. 1 图书信息表构造字段名称数据类

40、型字段长度可否为空说明bookNumvarchar45NoKey图书号bookNamevarchar45Yes图书名pricevarchar45Yes单价authorvarchar45Yes作者pressvarchar45YestimeInvarchar45Yes入库时间borrowervarchar45Yes借阅者表4.1在数据库中对应的视图如图4.2所示。图4.2 数据库book表DDL信息:CREATETABLEbook(bookNumvarchar(45)defaultNULL,bookNamevarchar(45)NOTNULLdefault,pricevarchar(45)defa

41、ultNULL,authorvarchar(45)defaultNULL,pressvarchar(45)defaultNULL,timeIntimestampNULLdefaultNULL,borrowervarchar(255)defaultNULL,PRIMARYKEY(bookName)ENGINE=InnoDBDEFAULTCHARSET=utf8114.2.2 管理员信息表构造设计login表此表的设计是为了储存管理员信息,根据管理需求的不同对其权限进展的设置,用于规定不同类型管理员的管理权限。表的具体构造设计如表4.2所示。表4.2 用户信息表构造字段名称数据类型字段长度可否为空

42、说明unamevarchar45NoKey用户名passwdvarchar45Yes密码表4.2在数据库中对应的视图如图4.3所示。图4.3 数据库login表DDL信息:CREATETABLElogin(unamevarchar(45)NOTNULLdefault,passwdvarchar(45)defaultNULL,PRIMARYKEY(uname)ENGINE=InnoDBDEFAULTCHARSET=utf84.2.3 学生用户信息表构造设计(reader表)学生用户信息表的设计是为了图书馆管理员对学生进展管理,其中学生ReadId都是唯一的,是学生在借阅图书时需要输入对读者身份进

43、展识别的信息。表的具体构造设计如表4.3所示。表4.3 读者信息表构造字段名称数据类型字段长度可否为空说明ReadIdvarchar45NoKey用户名readPasswdvarchar45Yes密码表4.3在数据库中对应的视图如图4.4所示。图4. 4 数据库reader表DDL信息:CREATETABLEreader(readerIDvarchar(45)NOTNULLdefault,readPasswdvarchar(45)defaultNULL,PRIMARYKEY(readerID)ENGINE=InnoDBDEFAULTCHARSET=utf8124.2.4 借阅卡表构造设计(st

44、udent表)借阅卡表的设计是为了绑定学生信息标识借阅书籍,其中学生stuNum都是唯一的。表的具体构造设计如表4.4所示。表4. 4 学生卡信息表构造字段名称数据类型字段长度可否为空说明stuNumvarchar45NoKey卡号stuPasswdvarchar45Yes密码表4.4在数据库中对应的视图如图4.5所示。图4. 5 数据库student表DDL信息:CREATETABLEstudent(stuNumvarchar(45)NOTNULLdefault,stuPasswdvarchar(45)defaultNULL,PRIMARYKEY(stuNum)ENGINE=InnoDBDE

45、FAULTCHARSET=utf8第5章 基于JAVA的图书馆管理系统的实现5.1用户登录当用户运行图书管理系统时,会出现的一个用户登录界面。用户输入正确的用户名和密码,即登录成功,系统会根据用户的身份进展相应权限划分:root管理员权限为最高权限,拥有root权限的管理员能进展所有操作。拥有管理员权限的操作员能对图书信息,读者信息,借书还书等进展相应的操作。如果登录信息有错误,那么系统提示用户名或密码错误的信息,并且无法进入登录后的主操作页面,只能点击“进入查询系统进展“所有藏书查询和“查询图书操作13。用户登录流程图如图5.1所示。图5.1 登录系统流程5.1.1登录页面图书借阅管理系统的

46、登录页面如图5.2所示。图5.2 登录页面登录界面局部代码: public void confirm()/验证用户和密码是否正确 Database db = new Database(); db.dbCon(); /连接数据库 try String uname = user_name.getText().trim(); String passwd = pass_word.getText().trim(); String query = select * from login where uname= + uname + and passwd= + passwd + ; ResultSet rs

47、 = db.stmt.executeQuery(query); if(rs.next() MainWin mainWin = new MainWin(uname); mainWin.setVisible(true); this.hide(); db.dbClose(); /关闭数据库连接 else JOptionPane.showMessageDialog(null, 用户名或密码错误!, 提示!, JOptionPane.YES_NO_OPTION); return; catch(SQLException g) System.out.println(E Code: + g.getErrorC

48、ode(); System.out.println(E M: + g.getMessage(); JOptionPane.showMessageDialog(null, 登录失败!); 5.1.2登录后的主页面登录后的主页面如图5.3所示。图5.3 主页面5.2退出图书管理系统当用户输入正确的用户名和密码登录到主页面时,点击第一行的“文件-退出或第二行最后一列的“退出,即可退出图书管理系统14。退出页面如图5.4所示。图5.4 退出页面退出图书管理系统局部代码如下: if(source = exitItem | source = exitButton) int selection = JOpt

49、ionPane.showConfirmDialog(null, 确定要退出吗?, 提醒!, JOptionPane.OK_CANCEL_OPTION, JOptionPane.WARNING_MESSAGE); if(selection = JOptionPane.OK_OPTION) System.exit(0); 5.3管理图书当用户输入正确的用户名和密码登录到主页面时,按需求点击第一行的“查看中的子按钮或第二行按钮,即可得到所需功能。5.3.1图书入库当用户输入正确的用户名和密码登录到主页面时,点击第一行的“管理-图书管理-图书入库或第二行第三列的“入库,会弹出一个“图书入库的可编辑界面

50、,输入各行信息点击确认即可参加图书其中价格为数字,整数小数皆可。图书入库流程图如图5.5所示。图5.5 图书入库流程图书入库界面如图5.6所示。图5.6 图书入库页面图书入库局部代码: public void insertRecord() Date date = new Date(); DateFormat df = new SimpleDateFormat(yyyy/MM/dd HH:mm:ss); String time = df.format(date);/ System.out.println(time); Database db = new Database(); db.dbCon(

51、); try String s = insert into book values( + book_num.getText() + , + book_name.getText() + , + price.getText() + , + author. getText() + , + press.getText() + , + time + ,null); /查询输入的图书号是否在数据库中存在 String query = select * from book where bookNum= + book_num. getText() + ; ResultSet rs = db.stmt.exec

52、uteQuery(query);/返回查询结果集 boolean moreRecords = rs.next();/判断结果集是否有数据 if(moreRecords) JOptionPane.showMessageDialog(this, 图书号已经被 + 使用,请重新输入); db.dbClose(); book_num.setText(); return; else int insert = db.stmt.executeUpdate(s); if(insert = 1) JOptionPane.showMessageDialog(null, 图书信息录入成功!); book_num.s

53、etText(); book_name.setText(); price.setText(); author.setText(); press.setText(); String str = select * from book; ShowBook showbk = new ShowBook(); showbk.showFirst(str); MainWin.label1.setText(书库现在共有图书 + ShowBook.count + 本); catch(SQLException g) System.out.println(E Code + g.getErrorCode(); Syst

54、em.out.println(E M + g.getMessage(); JOptionPane.showMessageDialog(null, 时间错误, 提示, JOptionPane.YES_NO_OPTION); 5.3.2图书编辑当用户输入正确的用户名和密码登录到主页面时,点击第一行的“管理-图书管理-图书编辑或第二行第四列的“编辑,会弹出一个“修改的可编辑界面,输入各行信息点击确认即可完成图书编辑其中价格为数字,整数小数皆可;点击图书号修改可切换到图书号修改界面,输入要修改的图书号点击确认即可完成图书号修改。也可选择要修改的单元格信息“单击鼠标右键-编辑或“双击直接修改15。图书入

55、库界面如图5.7所示。图5.7 图书编辑流程按图书号编辑图书界面如图5.8所示。图5.8 图书编辑页面按其他信息修改编辑图书界面如图5.9所示。图5.9 图书编辑页面图书编辑局部代码: public void editBook(int index) Database db = new Database(); db.dbCon(); String updateBookNum = update book set bookNum= + book_num.getText() + where bookNum= + MainWin.sbookNum + ; String updateBookName = update book set bookName= + book_name.getText() + where bookNum= + book_num.getText() + ; String updatePrice = update book set price= + price.getText() + where bookNum= + book_num.getText() + ; String updateAuthor = update book set author= + author.getText() + where bookNum= + book_num.ge

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!