一、实验目的
题目七 图书信息管理系统
1 功能描述
设计一个图书信息管理系统,使之具有新建图书信息、显示、插入、删除、查询和排序等功能。
2 具体设计要求
图书信息包括:图书编号、书名、作者名、出版单位、出版时间、价格等。
系统以菜单方式工作:
① 图书信息录入(要求图书信息用文件保存)
② 图书信息浏览
③ 插入图书信息
④ 查询(可以有多种查询方式,如按书名查询、按作者名查询、按价格查询等);
⑤ 排序(可以按图书编号排序、按书名排序、按出版时间排序、按价格排序等);
⑥ 修改图书信息
⑦ 删除图书信息
二、项目概况
1.总述
此项目为图书信息管理系统,是一个采用了mysql+mybatis框架+java编写的maven项目
2. 技术栈选择
Mysql,mybatis
3.环境介绍
数据库:mysql8.0
框架:mybatis
项目结构:maven3.0
语言:Java
Jdk版本:jdk11.0.5(Jdk8.0以上)
编写的IDE:IDEA 2020.01
依赖jar包:
4. 功能概述
该图书信息管理系统实现了便捷的图书信息管理,利用命令行操作的方式让用户的操作更为简洁。
本系统提供Sql和noSql两种运行模式。
Sql模式直接对mysql数据库进行操作,便于数据的持久化和规范化,让数据能够更加便捷高效,同时可以存储大量数据,便于进行大数据的管理,如果你想真正用此系统管理你的信息,建议采用此种模式。
noSql模式是把数据载入内存中,优点是速度快,但缺点也很明显,在面对大量数据的情况下显得有些力不从心,此模式建议在数据量小的情况下使用。
两种模式都支持以下功能:
5.功能结构
6.项目文件结构
三、数据结构描述
1.实体类Book(持久化层)
2.Sql模式下的数据库结构
库名:library
表名:books
字段名 | 代表含义 | 数据类型 | 格式 |
id | 图书编号 | INT | 主键,PK,not null |
title | 书名 | VARCHAR(20) | not null |
name | 作者名 | VARCHAR(20) | not null |
publisher | 出版商 | VARCHAR(20) | 无 |
time | 出版时间 | DATE | 无 |
price | 价格 | DECIMAL(7,4) | 无 |
3.Sql模式下的Mapper映射(接口结构)
4.noSql模式下的数据结构
采用LinkedList来维护图书信息
四、程序模块描述
该项目大致分为两个一级模块,分别在两个java文件中
各个文件内用分别有若干个二级模块
1.图书信息录入(通过文件录入)模块
2. 图文信息浏览模块
3. 插入模块
4. 查询模块
其下按查询条件有分为若干个三级模块
5. 排序模块
其下按排序条件有分为若干个三级模块
6. 更新模块
7. 删除模块
8. 写出模块
至于各模块的功能,见名知意,在此就不一一赘述了。
而对于各个模块的返回值和参数,容我卖个关子,此内容将在下个模块中讲解!
五、主要功能模块的算法流程图
1.Sql模式下的算法流程(以查找为例)
2. 各个模块间的连接算法流程
"套娃"式的连接方式
何为"套娃"?
可以理解为类似递归的连接方式。
与递归有什么不同?
如果采用递归,就要把低层级的模块套在高层级的模块里。这样子虽然连接了各个模块,达到了类似菜单的效果,但有以下两个较为致命的缺点:
当运行完一个模块后,该模块就运行结束,无法做到循环操作,这与实验要求不符
由于该项目是一个系统,各模块间要不断退出重进,循环多次的递归会造成堆栈不断压缩,有堆栈溢出风险
那我们该如何做呢?
对于第一个缺点,我采用了一个死循环来解决;对于第二个缺点,我的思路就是把改变模块重复调用的时机和位置,让它既能达到效果,又不会导致堆栈溢出
基本思路:
每个函数都有一个整数类型的返回值,只要返回1,就说明该级模块需要退回上一级;返回0则说明不需要,即留在当前模块。
而是留在当前模块还是返回上一级模块,由该模块(记为模块3)的上一级(记为模块2)控制,如果模块3返回一了,就在模块2的上一级(记为模块1)再次调用模块2,即可做到返回上一层;而如果模块3返回0则在模块2再次循环调用,直至模块返回1
这样做不仅能实现功能,而且能避免多次"套娃"导致堆栈溢出的风险