链接:https://pan.baidu.com/s/1f4kY1Ez8KHfw8nhOYrf88w一、功能要求:
提取码:mdt4
- 实现用户注册和登录功能。
- 支持对图书的增删改查。
- 查找方式可分为:模糊查询(按书名模糊查询、按作者姓名查询和按照分类查询)和精确查询(按照书号查询)两种。
- ‘分类’是写在数据库中的,查询、添加、修改书籍信息时作为下拉列表框出现。在系统中实现对分类的增删改查。
- 精确查询可以直接显示书籍详细信息。模糊查询显示查询到的所有书籍的概要信息,点击‘查看’可以进入详细信息页面。
- ‘添加书籍’单独设置为一个页面。
- ‘删除书籍信息’功能设置在查询到的单条书籍信息处。
1、数据库设计
(1)概念模型(综合E-R图)
该系统中存在三个实体,类别、用户和图书,其中各实体的属性如下,图书和类别具有1对多的关系,一个类别包含多个图书,一个图书只能所属于一个类别。
文章图片
(2)关系表(字段名、数据类型、长度、约束、说明)
用户表
文章图片
分类表
文章图片
注:为classnum设置触发器。原因:classnum格式为字符串不能直接使用自动增长,且格式一定为CN+’三位数字’;而且在实际操作中并不会对分类的内置编号进行操作,即对外是透明的,这就需要系统自己对编号进行维护。作用:实现在规定格式上的自动增长。
图书表
文章图片
2、界面设计
a) 刚进入系统的登录界面。
文章图片
b) 注册界面
文章图片
c) 系统首页。
菜单栏可以在首页和分类管理页面进行切换。中间是输入书号进行查询的精确查询功能。下方可以点击‘查找图书’对所有图书进行模糊查询。点击添加图书,进行图书的添加。
文章图片
d) 对分类的管理页面。
中间的主题部分展示所有的分类,下面是对分类的一些操作,将选中的全部取消;输入分类名后点击添加;删除所有选中的分类。
文章图片
g) 模糊查询页面
在上面输入或选择查询方式,点击查询。在多个框中输入,按第一个功能进行查询。
选中列表中的数据后才可以进行下面的查看,修改删除操作。
文章图片
f) 书籍详细信息页面
文章图片
e) 添加页面(修改页面和添加页面样式相同)
文章图片
【期末备考|C#、.NET实现的一个图书管理系统(大作业)】T_classnum触发器(上面提到的设置分类编号自增的触发器)
CREATE
TRIGGERT_classnum
BEFORE INSERT ONclassify
FOR EACH ROW BEGIN
SET new.classnum=CONCAT(‘CN’,LPAD((IFNULL((SELECT SUBSTRING(classnum,3,3) FROM classify WHERE classnum=(SELECT classnum FROM classify ORDER BY classnum DESC LIMIT 1)),0)+1),3,‘0’));
END;
说明:在每次对classify进行插入信息之前触发。这里的’new’是insert触发器的内置对象,表示将新的classnum值设为后面的值。Concat拼接函数,是将’CN’和后面的值拼接起来。Lpad函数将值填充为3位,不足三位在左边补0(如:当值是1时,将值补为001)。Ifnull是判断是否有值,如果有使用它,如果没有返回0。其中的查询语句作用:将classify表中的数据按照classnum降序排列,选取第一条数据(即最大值),然后将选取的最大值如-‘CN003’,进行截断,选取出值3(如果表中没数据,选取的值就为null)。
推荐阅读
- java学习日记|2022-08-10反射
- 牛客网|【Java刷题进阶】基础入门篇⑤
- java|关于微信小程序与Java后台交互数据中中文乱码问题的讨论
- PHP毕设含lunwen|含文档+PPT+源码等]精品基于PHP实现的好物优购商城|电商小程序[包运行成功]计算机毕业设计PHP毕业设计项目源码计算机PHP毕业设计微信小程序
- java|抖音API接口(item_search-根据关键词取商品列表)
- java|抖音API接口(item_get-获得抖音商品详情)
- JS知识总结|【JavaScript复习十八】预解析
- JS知识总结|【JavaScript复习十七】作用域以及变量提升
- 牛客网|【Java刷题进阶】基础入门篇③