




已阅读5页,还剩33页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
焦作大学信息工程学院焦作大学信息工程学院 Java Java 实训实训 报告报告 题目 题目 图书管理系统图书管理系统 班级 班级 网络 网络 1 1 班 班 姓名 张姓名 张辉辉 学号 学号 20112011 年年 1212 月月 2222 日日 沈阳工程学院课程设计报告 目录 摘 要 随着信息技术的发展 计算机已被广泛的应用于社会的各个领域 成为推动社会发展的 技术动力 而在计算机应用中 软件的作用十分突出 软件已经发展成为信息技术的核心 主导着信息产品的开发和信息技术市场的进一步的开拓 软件产业已成为社会信息化进程中 的一个战略性产业 在软件技术的应用中软件的开发技术尤其是应用型软件产品的开发技术 成了重中之重 不断开发适应用户需求 市场需要的新型软件产品 尤其是在校园里 各种 软件的应用无处不在 为我们的学习和生活提供了方便 学校的图书馆不仅给我们提供看书 学习的地方 还给我们提供了一套功能齐全的图书馆系统 方便我们搜索书籍 借阅图书 我们本次的 Java 课程设计的最终目标是实现一个图书馆管理系统 使其具有一般图书 管理系统所具有的功能 可以实现管理员日志 管理员添加 管理员退出 读者添加 读者 修改 读者查询 读者删除 新书入库 书籍查询 书籍借阅与归还等功能 因为 Java 是 一门很优秀的编程语言 具有面向对象 与平台无关 安全 稳定和多线程等特点 所以用 Java 编程为我们本次程序的编写提供了方便 在设计中我们主要进行了数据库及类的设计 把整系统分成了 15 个类和 5 个表 通过应用 awt swing sql util 等包 合理的添加了按 钮 菜单 文本框 文本区 表格等组件类 还包含窗口 面板等容器类 经过设计者合理 的布局 完成了窗体的设计 并通过建立 JDBC ODBC 桥接器连接到 Access 数据库后 向 数据库发送 SQL 语句实现程序与数据库中表间的消息通信 从而实现了相应的图书馆管理 系统的功能 本文主要分为绪论 系统功能介绍 数据库需求分析 系统功能实现 结论 致谢 参 考文献 7 大块 在绪论中介绍了本次课设选题的缘由及思想 系统功能介绍中详细介绍了本 图书管理系统的整体思想及其具体功能 在数据库需求分析中详细说明了数据库的需求分析 概念设计及表的设计 在系统功能实现中主要通过抓图来体现设计的结果 总之 我们的整 体设计思想均在报告中体现 关键词 图书馆管理系统 Java 程序设计语言 Access 数据库 目 录 摘 要 I 第 1 章 绪 论 1 第 2 章 系统功能介绍 2 2 1 系统功能总框图 2 2 2 模块功能介绍 2 2 2 1 管理员模块功能介绍 2 2 2 2 读者管理 3 2 2 3 书籍管理模块功能介绍 3 2 2 4 书籍借阅与归还功能介绍 4 沈阳工程学院课程设计报告 目录 2 2 5 借阅超时功能介绍 4 2 3 组内任务分工 4 第 3 章 数据库设计 5 3 1 数据库需求分析 5 3 2 数据库概念结构设计 5 3 3 数据库表的设计 6 第 4 章 系统功能实现 8 4 1 管理员模块功能实现 8 4 1 1 管理员登陆 8 4 1 2 管理日志 10 4 1 3 管理员添加功能实现 11 4 1 4 管理员切换 13 4 2 读者管理模块功能实现 14 4 2 1 读者添加 14 4 2 2 读者修改 15 4 2 3 读者查询 17 4 2 4 读者删除 18 4 3 书籍管理模块功能实现 19 4 3 1 新书入库实现 19 4 3 2 查询功能实现 21 4 4 书籍借阅与归还功能实现 23 4 4 1 借阅书籍功能实现 23 4 4 2 归还书籍功能实现 25 4 5 借阅超时功能实现 28 结 论 30 致 谢 31 参考文献 32 沈阳工程学院课程设计报告 第 1 章 绪论 0 第 1 章 绪 论 随着社会经济的迅速发展和科学技术的全面进步 计算机事业的飞速发展 以计算机与 通信技术为基础的信息系统正处于蓬勃发展的时期 随着经济文化水平的显著提高 人们对 生活质量及工作环境的要求也越来越高 书籍做为人类的精神食粮 在现代社会中越来越受 到重视 大量的书籍出现在市场上 人们有了各种各样不同的选择 与此同时 为了管理大 量的图书 图书管理系统也大量的出现 随着图书的大量增加 其管理难度也越来越大 如 何优化管理也就成为了一个大众化的问题 现已有的图书管理系统 其功能已十分强大 为了便于管理员对图书管理系统进行妥善 的管理和读者的查询 图书管理系统为管理员提供了管理日志 管理员添加 管理员切换 读者添加 读者修改 读者查询 读者删除 新书入库等功能 为读者提供了书籍查询 读 者借阅信息查询 图书网上续借等很多功能 大学为我们提供了自由的学习环境 使我们有更多的时间到图书馆借阅书籍 让我们可 以随时掌握各方面的知识 不断提高自我 充实自我 但由于图书馆藏书成千上万 我们很 难一本一本的去查找自己感兴趣的书籍 因此我们会经常用到学校为我们提供的图书管理系 统 用时间长了便对此产生了兴趣 正好本次课程设计为我们提供了良好的机会 让我们亲 自设计并实现了图书管理系统的部分功能 设计一个图书管理系统必不可少的必须对全管书籍进行分类汇总 而这就是我们所说的 数据库设计的第一阶段 需求分析 在这一阶段除了对具体情况诸如实行对管理员的管理 对读者的管理 书籍管理 书籍的借阅与归还 借阅超时等功能的实现 还需要对用户的需 求进行调查和分析 否则就失去了设计这个系统的意义了 对于界面的设计我们应该追求的是 美观 易读性强 清晰度高 原则是 不能因为刻 意追求美观而以整个界面的清晰度的牺牲作为代价 不能为了清晰度而抛弃对易读性的追求 再设计的过程中我们应该根据实际的情况进行设计 做到具体问题具体分析 不刻意追求原 则 在对应的界面与 Access 数据库建立连接 并实现对应的 SQL 语句进行实现将产生的结 果显示出来 并运用捕捉异常的方法 将异常信息显示出来 实现 SQL 语句的时候借助前台开发工具中关于数据处理的控件来完成 对于读者而言 他们的需求是了解图书的基本情况 自己的借阅情况 总而言之就是实现对各个信息表的查 询 对于图书管理员而言要实现的功能相对而言比较多 例如实现新书入库 Access 数据库 表的创建 系统的维护等等 这些都需要设计和实现的 沈阳工程学院课程设计报告 第 2 章 系统功能介 绍 1 第 2 章 系统功能介绍 2 1 系统功能总框图 图书馆管理系统功能总框图 如图 2 1 所示 图 2 1 系统功能框架图 2 2 模块功能介绍 2 2 1 管理员模块功能介绍 1 管理员登陆 此模块主要是利用 MenuBar 添加菜单条 利用 Menu 和 MenuItem 添加菜单和菜单的各 图书馆管理系统 管 理 员 读 者 管 理 书 籍 管 理 书 籍 借 阅 归 还 管 理 员 管 理 日 志 管 理 员 添 加 管 理 员 切 换 读 者 添 加 读 者 信 息 修 改 读 者 删 除 新 书 入 库 书 籍 查 询 借 阅 书 籍 归 还 书 籍 借 阅 超 时 读 者 信 息 查 询 沈阳工程学院课程设计报告 第 2 章 系统功能介 绍 2 个参数 通过事件 ActionEvent 可以实现进入各个模块如管理日志 管理员添加 管理员切 换 读者添加 读者修改 读者查询 读者删除 新书入库 书籍查询 借阅书籍 归还书 籍 借阅超时及退出的功能 2 管理日志 此模块可以清楚的显示出书籍借阅与归还的信息 包括书号 书名 图书证号 借 还 操作日期 已付款额 读者可以通过此模块实现的功能清楚的了解图书被借阅和归还的详细 信息 从而给读者带来了很多方便 3 管理员添加功能介绍 此模块功能是增加新管理员的登陆帐户 在图书馆管理系统中必须有每一个管理者的帐 户让其可以正常进行新图书证的办理 借阅书籍和归还书籍等系统管理 所以在管理员功能 模块中增加了管理员添加这个功能 4 管理员切换 此模块的主要功能是进行管理员之间的切换 即单击管理员菜单下的管理员切换 就会 退出当前管理员界面 从而出现管理员切换窗口 而另一管理员就可以在管理员切换窗口中 的用户名和密码两栏中通过输入自己的用户名和密码直接进入该系统 2 2 2 读者管理 1 读者添加 此模块主要的实现功能是添加新的读者信息 即当有新的读者要看查看本图书馆中的书 藉 可以通过此功能实现 当数据库中存在其新信息 即成为本图书馆的新一位读者 其中 信息分别包括图书证号 学生姓名 性别 系别 班级 同时可有三项功能在此处实现 即 添加 重置以及返回 2 读者修改 此模块主要的实现功能对有信息更新的读者进行即时修改 以随时更新读者在数据库中 的信息 本模块通过图书证号确定读者 可对读者信息的新图书证号 学短姓名 性别 系 别 班级 此处可分别实现对该功能的修改 重置 返回 3 读者查询 此模块主要可对所要了解的读者信息 即把读者的信息从数据库调出来 显示在该窗口 中的文字区域 查询方式分别有按图书证查询 按姓名查询 按班级查询 按年级查询 并 可通过办理入相应的关键字 更加缩小查询范围 此处可实现查询和返回功能 4 读者删除 此模块可以删除一些不再使用本系统的读者资料 从而达到对数据库中的清理 即清除 一些不必要资料 此处有四种删除途径 分别为按图书证号删除 按姓名删除 按班级删除 安年级删除 并可通过所输入的关键字尽快找到所要删除的资料 此处可分别实现对该功能 的修改 重置 返回 2 2 3 书籍管理模块功能介绍 1 新书入库功能介绍 沈阳工程学院课程设计报告 第 2 章 系统功能介 绍 3 此模块主要的实现功能是将新来的图书输入到图书馆管理系统的书库当中 其中主要按 如下信息往书库中输入 这部分的操作主要是便于书库合理的管理 有利于读者能够对新书 有 一个更详细的了解 其中包括如下信息 新书书号 新书名称 新书出版日期 新书出版社 入库数量 编写作者 新书单价 2 书籍查询功能介绍 在图书馆管理系统中书籍查询是最基本的功能 读者可以根据自己的需求来查询想要借 阅的书籍 本系统是用 Java 应用程序和 Access 数据库一起开发的其中利用 Java 来编程实现 功能的代码和布置运行界面 界面是由检索项 检索词和显示文本区三个部分组成的用户根 据自己的需要在检索项中选择自己所要按什么字段进行查询 其中书籍查询功能的检索项中 可以按书号查询 按书名查询 按作者名查询 按出版社查询 按入库时间查询等基础查询 选择检索项后用户只要在检索词中添写自己所要查询的内容并确定键确认后用户要查询的内 容就可以在显示文本区中显示出来 用户可以根据显示的信息得知自己所要借阅书籍的情况 2 2 4 书籍借阅与归还功能介绍 1 借阅书籍功能介绍 此模块主要实现读者可凭有效的图书证号 借阅图书馆内未借出的图书 输入图书证号后 可显示了该图书证持有者的全部信息 包括借书证号 姓名 性别 所在班级 所属系部 当前可借阅图书个数 供读者确认信息 通过输入有效的图书编号 查询该图书的全部信息 包括书号 书名 作者 出版社 是否借出 价格 借阅成功后 将该图书证号 书号 借阅日期 应还日期信息插入到数据库的表中进行记录 2 归还书籍功能介绍 此模块主要实现读者凭所要归还图书的图书证号归还图书 输入所要归还的图书编号后 可显示了该图书证持有者的全部信息 包括借书证号 姓 名 性别 所在班级 所属系部 当前可借阅图书个数 供读者确认信息 还书成功后 从数据库中删除该书的借出记录 并修改数据库中的相应信息 2 2 5 借阅超时功能介绍 此模块主要实现显示过期图书的信息 包括图书证号 书号 借阅日期 应还日期 提 醒读者还书 2 3 组内任务分工 组内分工情况如下表 2 1 所示 表 2 1 组内分工情况表 组长邹刚读者添加 查询 修改 删除 沈阳工程学院课程设计报告 第 2 章 系统功能介 绍 4 罗姗姗书籍借阅与归还模块 借书超期限子系统 组员李呈呈管理员添加 新书入库 按指定条件进行图书查询 刘兰兰数据库创建 登陆界面设计 管理员模块 沈阳工程学院课程设计报告 第 3 章 数据库设 计 5 第 3 章 数据库设计 在此图书馆管理系统中 使用到了一个重要的连接 即与数据库 Accesss 相连 数据库 中存有图书馆中所信息 包括读者信息 管理员资料 借阅与退还记录 所有与管理有关的 数据皆在其中 是保证系统能够正常实现各种功能的一架桥 3 1 数据库需求分析 Admi 表 即管理员表 记录了用户名和密码 Admirz 表 即管理日志表 记录了书号 书名 图书证号 借 还 操作日期 已付 款额 book 表 即图书表 记录了书号 书名 作者 出版社 入库时间 是否借出 价 格 borrowbook 表 即借阅表 记录了图书证号 书号 借阅日期 应还日期 person 表 即读者表 记录了图书证号 姓名 性别 系别 班级 3 2 数据库概念结构设计 图书馆管理系统 E R 图 如图 3 1 m n 读者 图书 管理员 性别系别班级姓名图书证号 书号 书名作者出版社 会化 密码 用户名 管理 管理 m n m 借阅 1 入库时间是否借出 价格 沈阳工程学院课程设计报告 第 3 章 数据库设 计 6 图 3 1 图书馆管理系统 E R 图 3 3 数据库表的设计 Admi 表 表中记录了可以使管理员进入该系统的用户名及密码 如表 3 1 所示 表 3 1 管理员信息表 字段名称数据类型长 度备 注 用户名文 本10 密 码文 本15 Admirz 表 表中记录借还书日志 用于存下所有对图书操作的记录 以便以后可以翻阅和查找 如 表 3 2 所示 表 3 2 管理日志表 字段名称数据类型长 度备 注 书号文 本10 书名文 本15 作者文 本15 出版社文 本15 入库时间DATE15 已付款额文 本10 book 表 表中记录了库内所有图书的所有资料 如表 3 3 表 3 3 图书表 字段名称数据类型长 度备 注 书号文 本10 书名文 本15 作者文 本15 出版社文 本15 入库时间DATE15 是否借出文 本10 沈阳工程学院课程设计报告 第 3 章 数据库设 计 7 价格文 本10 person 表 表中记录库中所有读者的相关信息 如表 3 4 所示 表 3 4 读者表 字段名称数据类型长 度备 注 图书证号文 本10 姓名文 本15 性别文 本15 系别文 本15 班级文 本15 borrowbook 表 表内记录了此时图书的借阅情况 如表 3 5 所示 表 3 5 借阅表 字段名称数据类型长 度备 注 图书证号文 本10 书号文 本15 借阅日期DATE15 应还日期DATE15 沈阳工程学院课程设计报告 第 4 章 系统功能实 现 8 第 4 章 系统功能实现 4 1 管理员模块功能实现 4 1 1 管理员登陆 此模块是整个系统最主要的部分 管理员可以通过此模块实现进入其余各个模块如管理 日志 管理员添加 管理员切换 读者添加 读者修改 读者查询 读者删除 新书入库 书籍查询 借阅书籍 归还书籍 借阅超时及退出的功能 图书管理系统管理员界面如图 4 1 所示 图 4 1 图书管理系统管理员 主要程序代码如下 public void actionPerformed ActionEvent e if e getSource itemAdmiqh this dispose In winin new In 系统登陆 if e getSource itemtc System exit 0 沈阳工程学院课程设计报告 第 4 章 系统功能实 现 9 if e getSource itemAdmixj CreatAdmi creatAdmi new CreatAdmi 管理员添加 if e getSource itemAdmirz WinTable wintable new WinTable 管理日志 if e getSource itemBookrk AddInfy addInfy new AddInfy if e getSource itemPersonlr Winpersonadd winperson new Winpersonadd 读者添加 if e getSource itemPersoncx Winpersonsearch winperson new Winpersonsearch 读者信息查询 if e getSource itemPersonxg Winpersonmodify winperson new Winpersonmodify 读者信息修改 if e getSource itemPersonsc Winpersondelete winperson new Winpersondelete 读者删除 if e getSource itemBookcx Windowjj ok new Windowjj if e getSource itemchaoshi day win new day if e getSource itemBorrowjs 沈阳工程学院课程设计报告 第 4 章 系统功能实 现 10 Borrowbook win new Borrowbook if e getSource itemBorrowhs Returnbook win new Returnbook 4 1 2 管理日志 此模块通过定义类 WinTable 继承顶层容器 JFrame 再添加普通容器 JScrollPane Jpanel 然后通过 BorderLayout 布局创建界面 最后主要通过数组利用 while 循 环在连接好的数据库中查找表 Admirz 中的内容 从而实现了可以清楚的显示出书籍借阅与 归还信息的功能 管理日志界面如图 4 2 所示 图 4 2 管理日志 主要程序代码如下 WinTable String s super s try Class forName sun jdbc odbc JdbcOdbcDriver catch ClassNotFoundException e System out println e try con DriverManager getConnection jdbc odbc sun 123 123 sql con createStatement rs sql executeQuery SELECT FROM Admirz while rs next 沈阳工程学院课程设计报告 第 4 章 系统功能实 现 11 k catch SQLException e System out println e try con DriverManager getConnection jdbc odbc sun 123 123 sql con createStatement rs sql executeQuery SELECT FROM Admirz a new Object k 6 while rs next for int j 0 j 6 j if j 5 a i j rs getString j 1 else a i j rs getDouble j 1 i con close catch SQLException e System out println e table new JTable a name Container con getContentPane getContentPane add new JScrollPane table BorderLayout CENTER setBounds 120 125 700 500 setVisible true validate addWindowListener new DisposeListener 沈阳工程学院课程设计报告 第 4 章 系统功能实 现 12 4 1 3 管理员添加功能实现 功能介绍 该程序主要实现管理员的添加 以便于让实行对图书管理员的管理 按照标 签提示输入信息 然后点击确定按钮 首先判断管理员名文本框中输入的文本信息是否符合 大于 3 个字符并小于 10 个字符的规则 如果不符合规则 则提示错误 如果符合规则 再 到 Admi 表中进行查询 如果相同则用提示框提示错误 若无相同则可注册 但还需要保证 前后两次的密码相同 才能成功注册 管理员登陆窗口如图 4 3 所示 图 4 3 管理员添加成功界面 主要程序代码如下 public void actionPerformed ActionEvent c String b textUser getText String d textPassword1 getText String g textPassword2 getText if c getSource buttonqk textUser setText null textPassword1 setText null textPassword2 setText null if c getSource buttonEnter c getSource textPassword2 if b length 10 JOptionPane showMessageDialog null 用户名应在 3 10 个字符之间 textUser setText null else try Class forName sun jdbc odbc JdbcOdbcDriver catch ClassNotFoundException e System out println e 沈阳工程学院课程设计报告 第 4 章 系统功能实 现 13 try con DriverManager getConnection jdbc odbc sun 123 123 sql con createStatement rs sql executeQuery SELECT FROM Admi WHERE 用户名 b if rs next String user rs getString 1 if b equals user JOptionPane showMessageDialog null 此管理员已被注册 警告 JOptionPane WARNING MESSAGE else if d equals g sql executeUpdate INSERTINTOAdmi VALUES b d this dispose JOptionPane showMessageDialog null 管理员注册成功 else JOptionPane showMessageDialog null 两次输入密码不一致 警告 JOptionPane ERROR MESSAGE con close catch SQLException e System out println e 4 1 4 管理员切换 此模块功能是退出当前管理员界面 进入管理员切换窗口 另一用户可以通过输入自己 的用户名和密码直接进入该系统 但此用户名和密码都必须与已经连接好的数据库中表 Admi 中的用户名和密码相吻合 管理员切换界面如图 4 4 所示 沈阳工程学院课程设计报告 第 4 章 系统功能实 现 14 图 4 4 管理员切换 主要程序代码如下 public void windowClosing WindowEvent e e getWindow dispose 4 2 读者管理模块功能实现 4 2 1 读者添加 功能介绍 添加新的读者 使其能够进入图书系统阅览图书 读者添加如图 4 5 所示 图 4 5 读者添加 主要程序代码如下 public void actionPerformed ActionEvent e if e getSource button1 添加 String ch text1 getText if ch length 5 沈阳工程学院课程设计报告 第 4 章 系统功能实 现 15 JOptionPane showMessageDialog null 请输入 5 位图书证号 text1 setText null else 连接数据库 String number name sex dept classes record insertStr number text1 getText name text2 getText if box1 getState true sex box1 getLabel else sex box2 getLabel dept text3 getText classes text4 getText rs sql executeQuery SELECT FROM person WHERE 图书证号 number if rs next JOptionPane showMessageDialog null 此图书证号已存在 警告 JOptionPane WARNING MESSAGE text1 setText null record number name sex dept cl asses insertStr INSERT INTO person VALUES record sql executeUpdate insertStr JOptionPane showMessageDialog null 添加成功 con close 4 2 2 读者修改 功能介绍 对读者需要修改的资料进行重定义 读者信息修改如图 4 6 所示 沈阳工程学院课程设计报告 第 4 章 系统功能实 现 16 图 4 6 读者信息修改 主要程序代码如下 public void actionPerformed ActionEvent e if e getSource button1 修改 String ch text1 getText if ch length 5 JOptionPane showMessageDialog null 请输入 5 位图书证号 text1 setText null else try 连接数据库 String number name sex dept classes newnum record updateStr newnum text5 getText number text1 getText name text2 getText if box1 getState true sex box1 getLabel else sex box2 getLabel dept text3 getText classes text4 getText sql con createStatement rs sql executeQuery SELECT FROM person where 图书证号 newnum 沈阳工程学院课程设计报告 第 4 章 系统功能实 现 17 if rs next rs1 sql executeQuery SELECT FROM person where 图书证号 number if rs1 next JOptionPane showMessageDialog null 此图书证号已存在 警告 JOptionPane WARNING MESSAGE text1 setText null else updateStr UPDATE person SET 图书证号 number 姓名 name 性别 sex 系别 dept 班级 classes WHERE 图书证号 newnum sql executeUpdate updateStr JOptionPane showMessageDialog null 修改成功 else JOptionPane showMessageDialog null 查无此人 连接数据库 con close 4 2 3 读者查询 功能介绍 可以对数据库中已有的读者信息进行查询 读者查询如图 4 7 沈阳工程学院课程设计报告 第 4 章 系统功能实 现 18 图 4 7 读者信息查询 主要程序代码如下 public void actionPerformed ActionEvent e if e getSource button1 e getSource text 查询 area setText null if str 按图书证号查询 str null String num text getText 连接数据库 rs sql executeQuery SELECT FROM person where 图书证号 num while rs next f false String number rs getString 图书证号 String name rs getString 姓名 String sex rs getString 性别 String dept rs getString 系别 String classes rs getString 班级 if flag area append 图书证号为 num 的学生信息如下 flag false area append n 姓名 name 性别 sex 系别 dept 班级 classes n if f area append 查无此人 catch SQLException c System out println c 4 2 4 读者删除 功能介绍 删除数据库中已有信息 读者删除如图 4 8 所示 沈阳工程学院课程设计报告 第 4 章 系统功能实 现 19 图 4 8 读者删除 主要程序代码如下 if e getSource button1 删除 area setText null if str 按图书证号删除 str null try Class forName sun jdbc odbc JdbcOdbcDriver catch ClassNotFoundException c System out println c 连接数据库 rs sql executeQuery SELECT FROM person where 图书证号 num if rs next area append 该信息已删除 String delStr DELETE FROM person WHERE 图书证号 num sql executeQuery delStr con close catch SQLException c 沈阳工程学院课程设计报告 第 4 章 系统功能实 现 20 System out println c 4 3 书籍管理模块功能实现 4 3 1 新书入库实现 功能介绍 此界面主要完成的功能是往数据库 book 表中添加新书的记录 在 book 表中 可查看最新的记录 在新书信息输入的过程中 会出现一些异常处理 如某个字段的信息没 有填写 新书信息输入字段的过程中 输入的字段类型与给定的字段类型与输入不匹配 如 货币 日期 输入的信息长度超过给定的字段长度等 如果填写的内容正确则可以成功将 新书添加入库 新书入库窗口如图 4 9 所示 图 4 9 添加新书入库界面 主要程序代码如下 public void actionPerformed ActionEvent c if c getSource button2 this dispose if c getSource button1 连接数据库 rs stm executeQuery select 书号 from book where 书号 textField1 getText if rs next JOptionPane showMessageDialog null 此书号已存在 警告 JOptionPane WARNING MESSAGE return float m String str1 str2 str3 str4 str6 str7 str8 str9 str10 沈阳工程学院课程设计报告 第 4 章 系统功能实 现 21 str1 textField1 getText str10 未借出 m Float parseFloat str9 str str1 str3 str8 str6 str7 str10 m String insert INSERT INTO book 书号 书名 作者 出版社 入库时间 是 否借出 价格 VALUES str stm executeUpdate insert textField1 setText JOptionPane showMessageDialog null 增加信息成功 con close catch Exception e JOptionPane showMessageDialog null 请认真检查各项 然后重试 异常警告 JOptionPane WARNING MESSAGE 4 3 2 查询功能实现 功能介绍 本系统包含两项一是检索项令一个是检索词 在检索项中用户可以根据自己 的需求来选择所要查询的项目并在检索词中添写自己所要查询的内容 本系统副带四个按钮 确定 取消 查看全库 该图书馆管理系统的查询界面如图 4 10 所示 图 4 10 查询系统界面 在该系统中为了用户使用方便还设有查看全库一项 用户可以通过这一功能来查看全库 的图书 所查询的内容将在下方的文本区中显示 其界面 4 11 所示 沈阳工程学院课程设计报告 第 4 章 系统功能实 现 22 图 4 11 查看全库信息 使用检索词必须得满足一定的查询条件才可以执行 用户必须得在检索项中选择查询方 式并添好检索词才可查询否则系统会显示未找到您要查找的内容并给以提示 如图 4 12 所 示 图 4 12 检索项按书号查询 主要程序代码如下 public void itemStateChanged ItemEvent e area setText null String name choice1 getSelectedItem area append 请您在检索项中输入您要查找的内容 public void actionPerformed ActionEvent e if e getSource button2 取消键 text1 setText null else if e getSource button3 返回键 this dispose else if e getSource button4 查看全库 Connection con Statement sql ResultSet rs try 建立数据源 沈阳工程学院课程设计报告 第 4 章 系统功能实 现 23 Class forName sun jdbc odbc JdbcOdbcDriver catch ClassNotFoundException c System out println c try con DriverManager getConnection jdbc odbc sun sql con createStatement rs sql executeQuery select from book while rs next String bookname rs getString 书名 String auther rs getString 作者 String chubanshe rs getString 出版社 String bookno rs getString 书号 String data rs getString 入库时间 String yesorno rs getString 是否借出 area append n 书号 bookno area append 书名 bookname area append 作者 auther area append 出版社 chubanshe 沈阳工程学院课程设计报告 第 4 章 系统功能实 现 24 area append n 入库时间 data area append 是否借出 yesorno con close catch SQLException c System out println c 4 4 书籍借阅与归还功能实现 4 4 1 借阅书籍功能实现 输入图书证号 0001 后点击查看按钮 可显示该读者信息 若输入图书证号错误 点击 查看按钮则会弹出借书证错误对话框 如图 4 13 所示 输入图书编号 按回车键 可显示 该图书信息 若输入图书编号错误 按回车键则会弹出图书编号错误对话框 如图 4 14 所 示 点击借阅按钮则会弹出图书借阅成功对话框 借阅书籍功能的具体实现如图 4 15 所示 图 4 13 借书证错误 图 4 14 图书编号错误 沈阳工程学院课程设计报告 第 4 章 系统功能实 现 25 图 4 15 借阅书籍 主要程序代码如下 public void actionPerformed ActionEvent e if e getSource tj if tscard getText equals null str1 tsid getText str2 tscard getText try Class forName sun jdbc odbc JdbcOdbcDriver catch ClassNotFoundException c System out println c 连接数据库 rs sql executeQuery SELECT FROM person where 图书证号 str2 String ls1 null ls2 null ls3 null int is1 0 if rs next ls2 str2 con close 连接数据库 rs sql executeQuery SELECT FROM book where 书号 沈阳工程学院课程设计报告 第 4 章 系统功能实 现 26 str1 if rs next if rs getString 是否借出 equals 未借出 ls1 str1 ls3 rs getString 书名 con close 连接数据库 rs sql executeQuery SELECT count 书号 FROM borrowbook where 图书 证号 str1 rs next is1 rs getInt 1 con close 连接数据库 if ls1 str1 if day 0 JOptionPane showMessageDialog this 您比应还日期晚了 String valueOf day 天归还 请交付相应滞纳金 延期还书 JOptionPane WARNING MESSAGE money day 10 tsid setText null 4 5 借阅超时功能实现 数据库 borrowbook 借书表 表中的 应还日期 字段中的时间与当前时间相比较 若 比当前时间早则说明该书借阅超时 那么该条记录将在此被显示出来 借阅超时功能具体实 现如图 4 18 所示 图 4 18 借阅超时 主要程序代码如下 连接数据库 Date nowtime new Date 当前日期 SimpleDateFormat matter1 new SimpleDateFormat yyyy MM dd String stime matter1 format nowtime String dyear stime substring 0 4 year2 Integer parseInt dyear 年 String dmoon stime substring 5 7 moon2 Integer parseInt dmoon 月 String dday stime substring 8 10 day2 Integer parseInt dday 日 rs sql executeQuery SELECT FROM borrowbook while rs next x x 1 rs beforeFirst 沈阳工程学院课程设计报告 第 4 章 系统功能实 现 30 a new Object x 4 while rs next 计算还书超过的天数 table new JTable a name sPanel add new JScrollPane table BorderLayout CENTER sPanel setEnabled false setBounds 0 0 700 400 setVisible true validate addWindowListener new WindowAdapter public void windowClosing WindowEvent e dispose 沈阳工程学院课程设计报告 结论 31 结 论 两周的 java 课程设计已经结束了 在这次课程设计中我组成员共同努力完成了任务 共同学习知识 虽然只是短短的两周时间 可是在这两周我们把课堂里老师讲的知识用到实 践中去了 感到非常高兴 在这次课设中我们不仅学到了知识 还锻练了团体合作的能力 在这次课设中我们真正体会到了小组合作精神的重要性 就如古语所说的 万众同心 齐力 断金 这对我们以后的工作有很大的帮助 制定设计题目很关键 我们小组组员共同研究讨论 最终选定了图书馆管理系统 之后 在收集资料的过程中 我们上网下载 到图书馆检索 众多资料 纷繁复杂 通过学习的理 论知识和广泛地资料分析我们制定了需求分析 在程序中我们主要用了 awt 包和 swing 包 界面排版主要用轻量级容器 box 来实现 页 面位置 大小是通过设置 setbounds 来控制的 我们不但成功的连接了数据库 也成功实现
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年3D打印技术的器官打印进展
- 农业银行2025黑河市秋招无领导小组面试案例题库
- 2025年3D打印的个性化医疗植入物
- 中国银行2025秋招面试典型题目及参考答案湖北地区
- 工商银行2025吉安市秋招无领导小组面试案例题库
- 工商银行2025张家口市秋招无领导模拟题角色攻略
- 中国银行2025萍乡市信息科技岗笔试题及答案
- 建设银行2025上饶市小语种岗笔试题及答案
- 建设银行2025兰州市秋招结构化面试经典题及参考答案
- 中国银行2025石家庄市秋招英文面试题库及高分回答
- 《基于模型的系统工程(MBSE)及MWORKS实践》全套教学课件
- 医务人员职业暴露与防护讲课
- 苏教版4四年级数学上册(全册)表格式教案
- 小学教育课件古诗
- BEC商务英语初级考试历年真题及答案6套
- 消除“艾梅乙”医疗歧视-从我做起
- 感恩老师课件教学课件
- GB/T 44625-2024动态响应同步调相机技术要求
- 不违反计划生育协议书模板
- (人教2024版)七年级数学开学第一课-课件
- 07FD02 防空地下室电气设备安装
评论
0/150
提交评论