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

上传人:xin****828 文档编号:6727798 上传时间:2020-03-02 格式:DOC 页数:62 大小:1.14MB
返回 下载 相关 举报
基于JAVA的图书馆管理系统设计(毕业论文).doc_第1页
第1页 / 共62页
基于JAVA的图书馆管理系统设计(毕业论文).doc_第2页
第2页 / 共62页
基于JAVA的图书馆管理系统设计(毕业论文).doc_第3页
第3页 / 共62页
点击查看更多>>
资源描述
Xxxx 大学 毕业设计 论文 基于 JAVA 的图书馆管理系统设计 Design of Library Management System Based on Java 学生姓名 xxx 学 号 xxxxxxxxx 专业班级 xxxxxxxxxx 指导教师 xxx 2014 年 5 月 作者声明 本人声明所呈交的论文是我个人在导师指导下进行的研究工作及取得的研究 成果 除了文中特别加以标注的地方外 没有任何剽窃 抄袭 造假等违反学术 道德 学术规范的行为 也没有侵犯任何其他人或组织的科研成果及专利 与我 一同工作的同志对本研究所做的任何贡献均已在论文中作了明确的说明并表示了 谢意 如本毕业设计 论文 引起的法律结果完全由本人承担 毕业设计 论文 成果归 xxx 大学所有 特此声明 作者专业 xxxxxxx 作者学号 xxxxxxx 作者签名 年 月 日 摘 要 随着网络技术的发展 计算机应用水平广泛提高 原来系统的时效性 数据 的正确性 操作的方便性上都存在不足 已影响到系统的正常使用 经过考察比 较 决定自己对图书管理系统重新设计 使系统能利用软件开发技术的成果 方 便图书的管理 图书管理系统是典型的信息管理系统 系统介绍了图书系统的开发过程 设 计中遇到的问题及解决方法以及提高当前应用程序或系统开发进度和改善工作性 能 利用其提供的各种面向对象的开发工具 首先在短时间内建立系统应用原型 然后 对初始原型系统进行需求迭代 不断修正和改进 直到形成用户满意的可行 系统 本次课程设计利用 JAVA 开发工具和 Mysql 数据库来开发这个图书管理系统 该系统要解决图书管理所要解决的问题 可以满足图书管理基本要求 包括添加 管理等功能 该系统能根据用户的需求 快捷方便的为读者提供借阅服务 关键词 图书管理系统 信息管理 JAVA Mysql Abstract Along with networking s development the computer application level s enhancement s expansion system s effectiveness the data accuracy in the operation conveniences has the insufficiency originally Has affected system s normal use After the inspection comparison 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 literature management The literature registration management system is the typical information management system The system introduces the literature referral system s performance 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 application 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 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 facilitates 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 章 开发环境及工具介绍 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 2MYSQL 8 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 章 数据库设计 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 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 章 绪论 随着计算机技术的飞速发展 计算机在企业管理中应用的普及 利用计算机 实现图书信息的管理势在必行 目前图书管理的借阅工作部分大多数还是手工管 理 工作效率很低 并且不能及时了解图书的种类和读者们比较需求的图书等 不能更好的适应当前读者的借阅要求 手工管理还存在这许多弊端 由于不可避 免的人为因素 造成数据的遗漏 误报 计算机信息化管理有着储存量大 速度 快等许多优点 提供给我们的处理信息及时快捷 本课题是图书馆系统的制作 能实现图书的管理 查询 借阅 极大地提高图书管理的效率 从而解决图书管 理复杂的问题 这也是图书管理的科学化 正规化管理 与世界接轨的重要条件 1 1 目前图书馆管理系统存在的问题 1 建立图书管理系统数据库管理图书和用户 因为图书馆的藏书种类多 数量多 将藏书准确地分门别类 快速检索 手 工进行非常困难往往是终于查到了信息 馆中没有此书或已被别人借走 图书馆 的规模越大 这个问题越突出 2 借书 还书工作量大 借书 还书频率越大 说明图书馆的作用越大 然而随之而来的大量的借书 还书登记 实存图书的更新以及借出图书超期 遗失等的处理 其工作量之大 往往是人工操作所难以胜任的 而且经常会出现这样那样的差错 3 图书统计工作难 藏书更新不能及时完成 图书馆的图书应根据科学技术的发展和教学工作的需要及时添加和更新 然 而由于藏书数量及图书种类越来越多 加上自然损耗 人为破坏 使图书的统计 工作难以及时完成 藏书的更新也就很难有针对性地进行 藏书的知识结构得不 到良好地控制 1 2 课题意义 随着计算机的广泛应用 其逐步成为现代化的标志 图书馆或者一些企业内 部 甚至是书店 在正常运行过程中总是面对大量的读者信息 书籍信息以及两 者相互作用产生的借书信息 还书信息 因此需要对读者资源 书籍资源 借书 信息 还书信息进行管理 及时了解各个环节中信息的变更 要对因此而产生的 单据进行及时的处理 为了提高图书馆或者企业内部对图书存销的自动化的管理 能够更快速的满足读者的要求 提高各种工作的效率 现对其设计相应的系统 以达到上述的目的 1 图书管理系统的主要功能是实现图书馆图书借阅和归还的管理的自动化 围 绕这一主要功能 本系统涉及到以下核心功能 借阅管理 归还管理 除了这些 核心功能外 还包括一些基本和辅助功能 它们是 用户管理 图书管理 图书 查询 1 3 本论文的研究内容 本课题主要研究的内容有 1 建立图书管理系统数据库管理图书和用户 2 完成菜单栏 有文件 管理 借阅管理 账户管理 查看等选项 3 管理图书的增删改查 实现借书还书功能 4 实现账户管理 密码修改功能 并能增加读者 管理员 5 能查看所有图书 已借图书 图书查询 1 4 可行性分析 1 4 1 经济可行性 由于图书管理系统是作为毕业设计由我们自己开发的 在经济上的投入甚微 系统建成之后将为今后图书管理提供很大的方便 估算新系统的开发费用和今后 的运行 维护费用 估计新系统将获得的效益 并将费用与效益进行比较 对今 后使用十分有利 2 1 4 2 技术可行性 技术可行性要考虑现有的技术条件是否能够顺利完成开发工作 软硬件配置 是否满足开发的需求等 本图书管理系统用的是 JAVA 开发语言 调试相对简单 当前的计算机硬件配置也完全能满足开发的需求 因此在技术上是绝对可行的 软件方面 由于目前单机模式相对发展成熟 故软件的开发平台成熟可行 它们 速度快 容量大 可靠性能高 价格低 完全能满足系统的需求 1 5 图书馆管理系统需求概述 1 5 1 系统目标 该系统主要建立一个基于 C S 模式的图书馆借阅管理系统 面对当起很多小 型图书管理仍是人工管理带来的检索速度慢 效率低 借阅归还图书量大 图书统 计工作量大 藏书不能完成及时更新的问题 该系统可以对跟系统的三个用户类 型的使用实现 1 对于读者在本系统的应用下可实现查询图书馆的藏书清单 方便的借 阅图书 续借图书 归还图书 能够查询自己的借阅图书情况 2 对于图书馆工作人员能够实现方便的对图书进行查询 方便的进行读者 借阅情况查询 方便的进行借书还书处理等 便捷的对图书信息进行添加 修改 删除 对读者信息进行相关添加 修改等操作 3 对于系统管理员可以对图书馆信息进行修改更新操作 对系统用户进 行添加 修改等操作 1 5 2 用户类和用户特性 图书借阅管理系统是一个基于 C S 模式的对图书馆进行高效率管理的应用系 统 它的用户主要是读者和图书管理员 学生通过该系统进行图书查询进而对自己 需要的图书进行借阅及自己的借阅情况进行查询 图书管理员则通过本系统实现 对图书及读者的高效管理 除此之外 还需要一个系统管理员对不同的用户进行 权限的设置等操作 3 第 2 章 开发环境及工具介绍 本系统采用面向对象的软件开发方法 以 Java 开发环境作为主要开发工具 使用 Mysql 作为关系数据库 配合功能强大的 SQL 查询语言实现建立关系数据 库 访问数据库 对数据库的更新 较好地实现了预定的需求功能 4 2 1 Java 开发环境 2 1 1 JAVA 简介 Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言 是由 Sun Microsystems 公司于 1995 年 5 月推出的 Java 程序设计语言和 Java 平台 即 JavaEE JavaME JavaSE 的总称 Java 自面世后就非常流行 发展迅速 对 C 语言形成了有力冲击 Java 技术具有卓越的通用性 高效性 平台移植性和安全 性 广泛应用于个人 PC 数据中心 游戏控制台 科学超级计算机 移动电话 和互联网 同时拥有全球最大的开发者专业社群 在全球云计算和移动互联网的 产业环境下 Java 更具备了显著优势和广阔前景 5 2 1 2 JAVA 主要特性 1 Java 语言是易学的 Java 语言的语法与 C 语言和 C 语言很接近 使得大多数程序员很容易学习 和使用 Java 另一方面 Java 丢弃了 C 中很少使用的 很难理解的 令人迷惑 的那些特性 如操作符重载 多继承 自动的强制类型转换 特别地 Java 语言 不使用指针 而是引用 并提供了自动的废料收集 使得程序员不必为内存管理 而担忧 2 Java 语言是强制面向对象的 Java 语言提供类 接口和继承等原语 为了简单起见 只支持类之间的单继 承 但支持接口之间的多继承 并支持类与接口之间的实现机制 关键字为 implements 总之 Java 语言是一个纯的面向对象程序设计语言 3 Java 语言是分布式的 Java 语言支持 Internet 应用的开发 在基本的 Java 应用编程接口中有一个网 络应用编程接口 java net 它提供了用于网络应用编程的类库 包括 URL URLConnection Socket ServerSocket 等 Java 的 RMI 远程方法激活 机制也是开发分布式应用的重要手段 4 Java 语言是健壮的 Java 的强类型机制 异常处理 垃圾的自动收集等是 Java 程序健壮性的重要 保证 对指针的丢弃是 Java 的明智选择 Java 的安全检查机制使得 Java 更具健 壮性 5 Java 语言是安全的 Java 通常被用在网络环境中 为此 Java 提供了一个安全机制以防恶意代码 的攻击 除了 Java 语言具有的许多安全特性以外 Java 对通过网络下载的类具有 一个安全防范机制 类 ClassLoader 如分配不同的名字空间以防替代本地的同 名类 字节代码检查 并提供安全管理机制 类 SecurityManager 让 Java 应用设 置安全哨兵 6 Java 语言是体系结构中立的 Java 程序 后缀为 java 的文件 在 Java 平台上被编译为体系结构中立的字 节码格式 后缀为 class 的文件 然后可以在实现这个 Java 平台的任何系统中 运行 这种途径适合于异构的网络环境和软件的分发 7 Java 语言是可移植的 这种可移植性来源于体系结构中立性 另外 Java 还严格规定了各个基本数 据类型的长度 Java 系统本身也具有很强的可移植性 Java 编译器是用 Java 实现 的 Java 的运行环境是用 ANSI C 实现的 8 Java 语言是解释型的 如前所述 Java 程序在 Java 平台上被编译为字节码格式 然后可以在实现这 个 Java 平台的任何系统中运行 在运行时 Java 平台中的 Java 解释器对这些字 节码进行解释执行 执行过程中需要的类在联接阶段被载入到运行环境中 9 Java 是性能略高的 与那些解释型的高级脚本语言相比 Java 的性能还是较优的 10 Java 语言是原生支持多线程的 在 Java 语言中 线程是一种特殊的对象 它必须由 Thread 类或其子 孙 类来创建 通常有两种方法来创建线程 其一 使用型构为 Thread Runnable 的 构造子将一个实现了 Runnable 接口的对象包装成一个线程 其二 从 Thread 类 派生出子类并重写 run 方法 使用该子类创建的对象即为线程 值得注意的是 Thread 类已经实现了 Runnable 接口 因此 任何一个线程均有它的 run 方法 而 run 方法中包含了线程所要运行的代码 线程的活动由一组方法来控制 Java 语 言支持多个线程的同时执行 并提供多线程之间的同步机制 关键字为 synchronized 11 Java 语言是动态的 Java 语言的设计目标之一是适应于动态变化的环境 Java 程序需要的类能够 动态地被载入到运行环境 也可以通过网络来载入所需要的类 这也有利于软件 的升级 另外 Java 中的类有一个运行时刻的表示 能进行运行时刻的类型检查 Java 语言的优良特性使得 Java 应用具有无比的健壮性和可靠性 这也减少了 应用系统的维护费用 Java 对对象技术的全面支持和 Java 平台内嵌的 API 能缩短 应用系统的开发时间并降低成本 Java 的编译一次 到处可运行的特性使得它能 够提供一个随处可用的开放结构和在多平台之间传递信息的低成本方式 特别是 Java 企业应用编程接口 Java Enterprise APIs 为企业计算及电子商务应用系统提 供了有关技术和丰富的类库 6 2 1 3 JAVA 优缺点 优势 Java 编程语言是个简单 面向对象 分布式 解释性 健壮 安全与系统无 关 可移植 高性能 多线程和动态的语言 Java 是功能完善的通用程序设计语言 可以用来开发可靠的 要求严格的应 用程序 Java 适合团队开发 软件工程可以相对做到规范 由于 Java 语言本身的 极其严格语法的特点 Java 语言无法写出结构混乱的程序 这将强迫程序员的代 码软件结构的规范性 这是一个很难比拟的优势 缺点 j2ee 的架构很完美 第一版软件可以做满意 但是很不适合互联网模式的持 续不断修改 互联网软件工程管理上的不足 持续的修修补补导致架构的破坏 2 1 4 相关技术 JDBC Java Database Connectivity 提供连接各种关系数据库的统一接口 作为数据源 可以为多种关系数据库提供统一访问 它由一组用 Java 语言编写的 类和接口组成 7 JDBC 为工具 数据库开发人员提供了一个标准的 API 据此可 以构建更高级的工具和接口 使数据库开发人员能够用纯 Java API 编写数据库应 用程序 同时 JDBC 也是个商标名 2 2 MYSQL 2 2 1 MYSQL 简介 MySQL 是一个开放源码的小型关联式数据库管理系统 开发者为瑞典 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 等多种操作系统 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 提供用于管理 检查 优化数据库操作的管理工具 10 支持大型的数据库 可以处理拥有上千万条记录的大型数据库 11 支持多种存储引擎 12 Mysql 是开源的 所以你不需要支付额外的费用 13 MySQL 使用标准的 SQL 数据语言形式 14 Mysql 对 PHP 有很好的支持 PHP 是目前最流行的 Web 开发语言 15 Mysql 是可以定制的 采用了 GPL 协议 你可以修改源码来开发自己 的 Mysql 系统 2 3 MyEclipse 开发工具 MyEclipse 企业级工作平台 MyEclipseEnterprise Workbench 简称 MyEclipse 是对 EclipseIDE 的扩展 利用它我们可以在数据库和 JavaEE 的开发 发布以及应用程序服务器的整合方面极大的提高工作效率 它是功能丰富的 JavaEE 集成开发环境 包括了完备的编码 调试 测试和发布功能 完整支持 HTML Struts JSP CSS Javascript Spring SQL Hibernate MyEclipse 是一个十分优秀的用于开发 Java J2EE 的 Eclipse 插件集合 MyEclipse 的功能非常强大 支持也十分广泛 尤其是对各种开源产品的支持十 分不错 MyEclipse 目前支持 Java Servlet AJAX JSP JSF Struts Spring Hibernate EJB3 JDBC 数据库链接 工具等多项功能 可以说 MyEclipse 是几乎囊括了目前所有主流开源产品的专属 eclipse 开发工具 第 3 章 系统总体结构设计及功能概述 3 1 图书馆管理系统总体结构图 绘制系统结构图的过程 实际上就是对系统功能模块进行分解设计的过程 即合理地将数据流程图转变为所需要的系统结构图 系统结构图将会使读者和用户能直观的了解系统的结构模式 理解系统的各 个功能的结构 能很好地方便用户使用和理解整个系统 本系统的结构如图 3 1 所示 图 3 1 系统结构图 根据需求分析的结果 按照 低耦合 高内聚 的原则 本系统将划分为以下 主要功能模块 管理员管理功能模块 学生用户管理功能模块 图书管理功能模 块 图书借阅归还功能模块 图书查询功能模块 3 2 文件模块功能 该模块的作用是安全退出图书管理系统 3 3 图书管理模块功能 该模块主要有图书入库 图书编辑和图书删除三个功能 其描述如表 3 1 所 示 表 3 1 图书信息管理描述 图书信息管理 功能描述 对图书进行基本操作和信息管理 访问的数据库表 图书类型表 book 进行的操作 添加 修改 删除图书 对图书的书号 书名 单价 作者 出版社等基本信息进行管理 产生的结果 对图书基本操作管理 对不同图书参数进行各自信 息的设置管理 结果存储位置或输 出 结果存储在图书类型表 book 中 结果在图书查询 页面输出 3 4 借阅管理模块功能 该模块主要包含借书 还书两个子模块 借书的描述如表 3 2 所示 表 3 2 图书借阅描述 图书借阅管理 功能描述 对读者借阅图书进行基本操作和信息管理 访问的数据库表 图书信息表 book 学生信息表 student 读者信息表 reader 进行的操作 对读者借阅图书进行管理 产生的结果 读者借阅成功 系统对借阅信息进行记录 结果存储位置或输 出 结果存储在图书信息表 book 中 结果在图书 借阅查询页面输出 还书的描述如表 3 3 所示 表 3 3 图书归还描述 图书归还管理 功能描述 对读者归还图书进行基本操作和信息管理 访问的数据库表 图书信息表 book 学生信息表 student 读者信息表 reader 进行的操作 对读者借阅图书进行管理 产生的结果 读者借阅成功 系统对借阅信息进行记录 结果存储位置或输 出 结果存储在图书归还表 book 中 3 5 账户管理模块功能 该模块主要包含密码修改 读者账户管理 根管理员功能三个子模块 密码修改的描述如表 3 4 所示 表 3 4 密码修改描述 密码修改 功能描述 对已登录系统的账户进行密码修改操作 访问的数据库表 管理员信息表 login 进行的操作 修改本账户密码 产生的结果 修改成功 旧密码将被新密码替换 结果存储位置或输 出 结果存储在管理员信息表 login 中 读者账户管理的描述如表 3 5 所示 表 3 5 读者账户管理描述 读者账户管理 功能描述 对读者账号进行基本操作和信息管理 访问的数据库表 读者信息表 reader 进行的操作 增加 删除读者账号 产生的结果 操作成功 系统对读者账号信息进行记录或修 改 结果存储位置或输 出 结果存储在读者信息表 reader 中 根管理员功能的描述如表 3 6 所示 表 3 6 根管理员功能描述 根管理员功能 功能描述 对管理员账号进行基本操作和信息管理 访问的数据库表 管理员信息表 login 进行的操作 增加 删除管理员账号 产生的结果 操作成功 系统对管理员账号信息进行记录或 修改 结果存储位置或输 出 结果存储在管理员信息表 login 中 3 6 查询模块功能 该模块主要包含所有藏书 已借图书 图书查询三个子模块 所有藏书的描述如表 3 7 所示 表 3 7 所有藏书描述 所有藏书 功能描述 对图书馆藏书进行查询 访问的数据库表 图书信息表 book 进行的操作 查询图书馆所有藏书 产生的结果 操作成功 系统对所有图书信息进行显示 结果存储位置或输 结果存储在图书信息表 book 中 出 已借图书的描述如表 3 8 所示 表 3 8 已借图书描述 已借图书 功能描述 对已借图书进行查询 访问的数据库表 图书信息表 book 进行的操作 查询已借图书 产生的结果 操作成功 系统对已借图书信息进行显示 结果存储位置或输 出 结果存储在图书信息表 book 中 图书查询的描述如表 3 9 所示 表 3 9 图书查询描述 图书查询 功能描述 对图书名进行模糊查询筛选出需要的图书 访问的数据库表 图书信息表 book 进行的操作 按图书名查询所需图书 产生的结果 操作成功 系统对筛选图书信息进行显示 结果存储位置或输 出 结果存储在图书信息表 book 中 第 4 章 数据库设计 4 1 数据库设计概述 数据库是整个系统的基石 数据库的设计优劣直接影响到整个系统的设计成 败 本节对数据库的设计进行专门阐述 数据库是数据管理的最新技术 十多年来数据库管理系统已从专用的应用程 序发展成为通用的系统软件 由于数据库具有数据结构化 最低冗余度 较高的 程序与数据独立性 易于扩充 易于编制应用程序等优点 较大的信息系统都是 建立在数据库设计之上的 因此不仅大型计算机及中小型计算机 甚至微型机都 配有数据库管理系统 9 数据库系统的出现使信息系统从以加工数据的程序为中心转向围绕共享的数 据库为中心的新阶段 这样既便于数据的集中管理 又有利于应用程序的研制和 维护 提高了数据的利用性和相容性 提高了决策的可靠性 目前 数据库已经 成为现代信息系统不可分割的重要组成部分 数据库技术也是计算机领域中发展 最快的技术之一 数据库设计是把现实世界的实体模型与需求转换成数据库的模型的过程 它 是建立数据库应用系统的核心问题 数据库及其应用的性能都建立在良好的数据 库设计的基础之上 数据库的数据是一切操作的基础 如果数据库设计不好 那 么其它一切用于提高数据库性能的方法收效都是有限的 数据库设计的关键是如 何使设计的数据库能合理地存储用户的数据 方便用户进行数据处理 设计数据库必须遵循一定的规则 在关系型数据库中 这种规则就是范式 范式是符合某一种级别的关系模式的集合 一般人们设计数据库遵循第三范式 即 数据库表中不包含已在其他表中包含的非主关键字信息 采用范式减少了数 据冗余 节约了存储空间 同时加快了增 删 改的速度 10 整个系统所包括的信息有图书信息 用户信息 管理员信息 图书状态信息 可将这些信息抽象为下列系统所需要的数据项和数据结构 1 图书信息 图书号 图书名 单价 作者 出版社 入库时间 借阅 者 2 管理员信息 用户名 密码 3 学生信息 用户名 密码 4 借阅卡信息 卡号 密码 注 带下划线表示主键 在这里使用 E R 图描述了图书借阅管理系统的数据模型 图书借阅管理系统 E R 图描述了该系统所涉及到的实体以及他们之间的关系 设计规划出的实体有 图 书信息实体 学生信息实体 管理员信息实体 具体结构如图 4 1 所示 图 4 1 数据库 E R 图 权限 学生 图书 管理员 用户名 出版社 用户名 卡号 图书名 图书号 单价 作者 入库时间 借阅者 办理 借书 4 2 数据库各表的设计 4 2 1 图书信息表结构设计 book 表 图书信息表主要用于存储图书馆中所藏图书的相关信息 其中的相关信息是 在图书入库时由图书管理员进行添加完善 此表主要用于读者和图书管理员对馆 中图书的查询 系统用户根据图书的某个属性进行查询 便可得知图书的其他相 关信息 表的具体结构如表 4 1 所示 表 4 1 图书信息表结构 字段名称 数据类型 字段长度 可否为空 说明 bookNum varchar 45 No Key 图书号 bookName varchar 45 Yes 图书名 price varchar 45 Yes 单价 author varchar 45 Yes 作者 press varchar 45 Yes 出版社 timeIn varchar 45 Yes 入库时间 borrower varchar 45 Yes 借阅者 表 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 NULL timeIn timestamp NULL default NULL borrower varchar 255 default NULL PRIMARY KEY bookName ENGINE InnoDB DEFAULT CHARSET utf8 11 4 2 2 管理员信息表结构设计 login 表 此表的设计是为了储存管理员信息 根据管理需求的不同对其权限进行的设 置 用于规定不同类型管理员的管理权限 表的具体结构设计如表 4 2 所示 表 4 2 用户信息表结构 字段名称 数据类型 字段长度 可否为空 说明 uname varchar 45 No Key 用户名 passwd varchar 45 Yes 密码 表 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 学生用户信息表结构设计 reader 表 学生用户信息表的设计是为了图书馆管理员对学生进行管理 其中学生 ReadId 号码都是唯一的 是学生在借阅图书时需要输入对读者身份进行识别的信 息 表的具体结构设计如表 4 3 所示 表 4 3 读者信息表结构 字段名称 数据类型 字段长度 可否为空 说明 ReadId varchar 45 No Key 用户名 readPasswd varchar 45 Yes 密码 表 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 ENGINE InnoDB DEFAULT CHARSET utf8 12 4 2 4 借阅卡表结构设计 student 表 借阅卡表的设计是为了绑定学生信息标识借阅书籍 其中学生 stuNum 号码都 是唯一的 表的具体结构设计如表 4 4 所示 表 4 4 学生卡信息表结构 字段名称 数据类型 字段长度 可否为空 说明 stuNum varchar 45 No Key 卡号 stuPasswd varchar 45 Yes 密码 表 4 4 在数据库中对应的视图如图 4 5 所示 图 4 5 数据库 student 表 DDL 信息 CREATE TABLE student stuNum varchar 45 NOT NULL default stuPasswd varchar 45 default NULL PRIMARY KEY stuNum ENGINE InnoDB DEFAULT CHARSET utf8 第 5 章 基于 JAVA 的图书馆管理系统的实现 5 1 用户登录 当用户运行图书管理系统时 会出现的一个用户登录界面 用户输入正确的 用户名和密码 即登录成功 系统会根据用户的身份进行相应权限划分 root 管 理员权限为最高权限 拥有 root 权限的管理员能进行所有操作 拥有管理员权限 的操作员能对图书信息 读者信息 借书还书等进行相应的操作 如果登录信息 有错误 则系统提示用户名或密码错误的信息 并且无法进入登录后的主操作页 面 只能点击 进入查询系统 进行 所有藏书查询 和 查询图书 操作 13 用户登录流程图如图 5 1 所示 图 5 1 登录系统流程 5 1 1 登录页面 图书借阅管理系统的登录页面如图 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 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 getErrorCode 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 JOptionPane showConfirmDialog null 确定要退出吗 提醒 JOptionPane OK CANCEL OPTION JOptionPane WARNING MESSAGE if selection JOptionPane OK OPTION System exit 0 5 3 管理图书 当用户输入正确的用户名和密码登录到主页面时 按需求点击第一行的 查 看 中的子按钮或第二行按钮 即可得到所需功能 5 3 1 图书入库 当用户输入正确的用户名和密码登录到主页面时 点击第一行的 管理 图书 管理 图书入库 或第二行第三列的 入库 会弹出一个 图书入库 的可编辑界面 输入各行信息点击确认即可加入图书 其中价格为数字 整数小数皆可 图书入库流程图如图 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 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 executeQuery 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 setText 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 System out println E M g getMessage JOptionPane showMessageDialog null 时间错误 提示 JOptionPane YES NO OPTION 5 3 2 图书编辑 当用户输入正确的用户名和密码登录到主页面时 点击第一行的 管理 图书 管理 图书编辑 或第二行第四列的 编辑 会弹出一个 修改 的可编辑界面 输 入各行信息点击确认即可完成图书编辑 其中价格为数字 整数小数皆可 点 击图书号修改可切换到图书号修改界面 输入要修改的图书号点击确认即可完成 图书号修改 也可选择要修改的单元格信息 单击鼠标右键 编辑 或 双击 直接修 改 15 图书入库界面如图 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 getText String updatePress update book set press press getText where bookNum book num getText String updateTimeIn update book set timeIn time in getText where bookNum book num getText String query select from book where bookNum book num getText int bookNameUpdated 0 priceUpdated 0 authorUpdated 0 pressUpdated 0 timeInUpdated 0 bookNumUpdated 0 try if book num setEditable ResultSet rs db stmt executeQuery query 返回查询结果集 boolean exist rs next 判断结果集是否有数据 if exist JOptionPane showMessageDialog null 该图书号已被使用 信息 JOptionPane YES NO OPTION return else bookNumUpdated db stmt executeUpdate updateBookNum else bookNameUpdated db stmt executeUpdate updateBookName priceUpdated db stmt executeUpdate updatePrice authorUpdated db stmt executeUpdate updateAuthor pressUpdated db stmt executeUpdate updatePress timeInUpdated db stmt executeUpdate updateTimeIn if bookNumUpdated 1 bookNameUpdated 1 this hide else JOptionPane showMessageDialog null 信息无法写入数据库 信息 JOptionPane YES NO OPTION String str select from book ShowBook showbk new ShowBook showbk showFirst str catch SQLException g System out println E Code g getErrorCode System out println E M g getMessage JOptionPane showMessageDialog null 时间格式错误 信息 JOptionPane YES NO OPTION finally db dbClose 5 3 3 图书删除 当用户输入正确的用户名和密码登录到主页面时 选择要删除的行 点击第 一行的 管理 图书管理 图书删除 或第二行第五列的 删除 会弹出一个可选择 确认 或 取消 的 警告框 点击确认即可完成删除 也可选择要删除的行后 单 击鼠标右键 删除 直接删除 图书删除流程图如图 5 10 所示 图 5 10 图书删除流程 图书删除界面如图 5 11 所示 图 5 11 图书删除页面 图书删除部分代码如下 public void delBook 删除操作时先判断是否选中表格行或表格行是否为空 int index MainWin table getSelectedRow int index MainWin table getSelectedRows if index length 0 if index length 0 index length 0 else int selection JOptionPane showConfirmDialog null 确定要删除所选中图书吗 警告 JOptionPane OK CANCEL OPTION JOptionPane WARNING MESSAGE if selection JOptionPane OK OPTION 连接数据库 Database db new Database db dbCon 将选中要删除的表格行第二项即图书号转换成字符串赋值给变量 str v try int n 0 for int i 0 i index length i String str v String MainWin table getValueAt index i 0 String s delete from book where bookNum str v 删除数据库中的记录 int del db stmt executeUpdate s if del 1 n if n index length JOptionPane showMessageDialog null 删除成功 JOptionPane showMessageDialog null 删除成功 信息 JOptionPane YES NO OPTION 更新显示藏书 else JOptionPane showMessageDialog null n 条记录被删除 index length n 条记录无法删除 信息 JOptionPane YES NO OPTION String str select from book ShowBook showbk new ShowBook showbk showFirst str MainWin label1 setText 书库现在共有图书 Sho
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 其他分类 > 大学论文


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

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


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