基于Java和MySQL的图书管理系统[通俗易懂]

Java图书管理系统设计人:wangyunpeng_bio项目需求随着计算机的普及和应用水平的提高,经过考察比较,决定利用自己的Java知识开发小型的图书管理系统,方便图书的管理。图书管理系统是典型的信息管理系统。本次作业利用JAVA开发工具Eclipse和MySQL数据库来开发这个图书管理系统。该系统要解决的图书管理所要解决的问题,可以满足图书管理基本要求,包括添加、管理等功能。…

大家好,又见面了,我是你们的朋友全栈君。

Java图书管理系统

设计人:wangyunpeng_bio

项目需求

随着计算机的普及和应用水平的提高,经过考察比较,决定利用自己的Java知识开发小型的图书管理系统,方便图书的管理。
图书管理系统是典型的信息管理系统。本次作业利用JAVA开发工具Eclipse和MySQL数据库来开发这个图书管理系统。该系统要解决的图书管理所要解决的问题,可以满足图书管理基本要求,包括添加、管理等功能。该系统能根据用户的需求,快捷方便的为读者提供借阅服务
图书管理系统应有以下功能:

  1. 读者库管理
  2. 书库管理
  3. 借阅管理
  4. 读者信息查询

图书管理系统主要针对书库的操作功能、所以系统应尽量满足需求、同时亦不可有多余或繁复的功能、令系统的操作和功能混乱。

项目地址

本项目地址:https://github.com/wangyunpengbio/Library/
免费下载方法:点那个“Clone or download”,再点“Download ZIP”就行了,感兴趣的话,大家可以点个Star
如果实在太初学者,不会下载的话,就在csdn上下载吧https://download.csdn.net/download/qq_29300341/9667678

需求分析

A.业务流程:

No. 业务流程 需求
1. 图书管理员登入系统 图书管理员需使用账号和密码登入。
2. 新增读者资料 新增读者资料,如姓名、性别、职位等。
3. 新增书籍资料 新增书籍资料,如书名、价格、种类等。
4. 读者库管理 选中读者库里的读者信息,即可更新和删除。
5. 书库管理 可以按“书编号查询”和“书名模糊查询”,继而选中书籍信息,即可更新和删除书籍分为在库和借出
6 借阅管理 输入读者编号,即可检阅读者的数据和借阅的图书,检阅顾客的数据和购买纪录。
7. 读者登入系统 读者需使用账号和密码登入。
8 借书 按书名模糊搜索,选中即可借阅图书
9 还书 检阅自己的读者信息以及已经借阅的图书,点击归还即可,不允许更改或删除读者数据,只允许查询,更改和删除功能由管理员负责。

以下是使用 实体联系模型-Entity Relationship来分析。

B.归纳实体和属性

No. 业务流程 对应的实体 实体的属性值
1. 图书管理员登入系统 Librarian nameUser password
2. 新增读者资料 Reader idReader nameReader kind sex password
3. 新增书籍资料 Book Author Publisher idBook,nameBook,price,kind,author,publisher Author.name, Author.workplace Publisher.name, Publisher.address
4. 读者库管理 Reader idReader nameReader kind sex password
5. 书库管理 Book idBook nameBook price kind autor publisher
6. 借阅管理 Borrow idReader idBook lendDate dueDate overtime
7. 读者登入系统 Reader idReader password
8 借书 Borrow idReader idBook lendDate dueDate overtime
9 还书 Borrow idReader idBook lendDate dueDate overtime

C.实体的模型

在这里插入图片描述

D.ER-实体关系

Author,Publisher To Book&Borrow&Reader To Librarian
在这里插入图片描述

设计

项目文件夹中,(代码总计:4800+行)
doc文件夹存放着生成的文档注释,可点击其中的index文件查看整个项目的注释

Src包下面含有五个包

  • Database用于存储数据库连接操作
  • Frame用于存储各个窗体界面
  • Model用于存储各个实体(表)对应的数据模型
  • Out_of_date用于存储初始时候写的界面,后来舍弃,不再调用。
  • SqlTools用于存储操作数据库的增删改查方法

image文件夹用于存放相关的界面图片,按钮图片
备注:程序不同界面的入口已经全部注释掉了,MainFrame是程序的唯一入口

程序细节设计:

  1. 登陆界面的密码回显,伴有跳转动画(此处利用了多线程,控制线程存活时间)
  2. 表格直接选中即可修改数据,更新数据时候默认有原始数据,可按不同方式搜索图书;
  3. 新增借阅信息时候,自动加入当前时间,并计算归还时间。(SQL函数NOW())
  4. 界面按钮,背景用Photoshop的重新设计,图形用户界面友好;
  5. 数据库设计达到第三范式,去除了所有非主属性对任何候选关键字的传递信依赖,冗余度低。
  6. 变量和方法命名符合规范,可读性强
  7. 不同的Model实体(表)对应不同的SqlTools操作,分开存放,程序复用性好,易扩展。
    使用
  8. 将SQL语句导入,字符集选utf8,不然有可能显示不了中文,数据库名称为library
    create database library;
  9. 推荐使用Mysql Front这个MySQL的前台,支持多句sql语句一起执行,百度第一个链接即可下载。
    http://dlsw.baidu.com/sw-search-sp/soft/6c/17997/MySQL-Front_V5.3.4.214_Setup.1435658094.exe
  10. Java环境中加入数据库的驱动,源程序里database包里DatabaseTools.java文件是有关数据库连接的操作源程序的用户名和密码皆为root,数据库名为:library不同电脑上运行需要稍微改一下这个代码。
  11. 登陆:
    图书管理员:用户名root密码 root或者wangyp密码123456
    **读者:用户名001密码 root **(注:数据库内读者的密码初始值皆为root)
  12. 在不同计算机上Eclipse使用,可能需要重新建立Java类库的路径
    本程序用1.8的jdk写的,所以最好用1.8的jre。
    代码放在1.8下面运行,连警告都不会出现,1.7和1.6显示效果不好。
    awt 和 swing 都依赖虚拟机的具体实现。所以不同平台表现不大一样。如果用javafx,界面才可以移植。
    而且编写用的笔记本电脑是高分屏,在本机上显示大小是正好的,到别的电脑上面有可能会出现界面过大的情况。
  13. 具体的文档注释已经生成,打开doc文件夹其中的index文件查看整个项目的注释
    在这里插入图片描述
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/128619.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • Poetry(2)Poetry的基本使用方式「建议收藏」

    Poetry(2)Poetry的基本使用方式「建议收藏」Poetry的基本使用准备工作如果你是在一个已有的项目里使用Poetry,你只需要执行poetryinit命令来创建一个pyproject.toml文件:poetryinit可看到

  • UE4 Slate四 SlateUI如何做动画「建议收藏」

    UE4 Slate四 SlateUI如何做动画「建议收藏」原创文章,转载请注明出处。点击观看上一篇《UE4Slate三SlateUI代码讲解》点击观看下一篇《UE4Slate五开篇》虚幻引擎SlateUI介绍1>前言2>SlateAnimation代码1>前言我们都知道在UMG里面如何创建一个UMG的动画,其实就是时间帧动画。那么在Slate纯手写的代码上如何做动画呢?2>SlateAnimation代码…

  • 聊聊IT外包公司(外包公司的运作模式和赚钱之道)

    聊聊IT外包公司(外包公司的运作模式和赚钱之道)聊聊IT外包公司(外包公司的运作模式和赚钱之道)外包分类1.人力外包2.项目外包先说说人力外包比如:华为公司很大,有很多项目在做,但是一些次要的,或者非核心的项目,如果华为公司自己招兵买马的话,那么成本会很高,像员工的社保,公积金等等这些都要华为自己掏钱,这时候,华为公司就会想了,能不能把这部分次要的项目包出去,包给其他公司,交给别人去做,这样的话,直接付款给外包公司就行了,项…

  • mapminmax函数 matlab,matlab mapminmax函数详解

    mapminmax函数 matlab,matlab mapminmax函数详解几个要说明的函数接口:[Y,PS]=mapminmax(X)[Y,PS]=mapminmax(X,FP)Y=mapminmax(‘apply’,X,PS)X=mapminmax(‘reverse’,Y,PS)用实例来讲解,测试数据x1=[124],x2=[523];>>[y,ps]=mapminmax(x1)y=-1.0000-0.3333…

  • 四种方法求最长回文子串

    四种方法求最长回文子串所谓回文串,就是正着读和倒着读结果都一样的回文字符串。比如:a,aba,abccba都是回文串,ab,abb,abca都不是回文串。一、暴力法最容易想到的就是暴力破解,求出每一个子串,之后判断是不是回文,找到最长的那个。求每一个子串时间复杂度O(N^2),判断子串是不是回文O(N),两者是相乘关系,所以时间复杂度为O(N^3)。stringlongestPali…

  • IP地址、子网掩码、默认网关和DNS服务器之间的联系与区别

    IP地址、子网掩码、默认网关和DNS服务器之间的联系与区别转自:[https://www.cnblogs.com/JuneWang/p/3917697.html]IP地址,子网掩码、默认网关,DNS服务器是什么意思?(一)问题解析问:IP地址,子网掩码,默认网关,DNS服务器,有什么区别呀?我知道没有IP地址就不能上网,我也知道没设DNS就不能上外网,可它们都有什么功能,有什么区别呢?还有真奇怪,我的计算机没设DNS,竟然能上QQ,却不能…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号