C#、.NET实现的一个图书管理系统(大作业)

链接:https://pan.baidu.com/s/1f4kY1Ez8KHfw8nhOYrf88w
提取码:mdt4

一、功能要求:

  1. 实现用户注册和登录功能。

  2. 支持对图书的增删改查。

  3. 查找方式可分为:模糊查询(按书名模糊查询、按作者姓名查询和按照分类查询)和精确查询(按照书号查询)两种。

  4. ‘分类’是写在数据库中的,查询、添加、修改书籍信息时作为下拉列表框出现。在系统中实现对分类的增删改查。

  5. 精确查询可以直接显示书籍详细信息。模糊查询显示查询到的所有书籍的概要信息,点击‘查看’可以进入详细信息页面。

  6. ‘添加书籍’单独设置为一个页面。

  7. ‘删除书籍信息’功能设置在查询到的单条书籍信息处。

二、系统设计
1、数据库设计
(1)概念模型(综合E-R图)
该系统中存在三个实体,类别、用户和图书,其中各实体的属性如下,图书和类别具有1对多的关系,一个类别包含多个图书,一个图书只能所属于一个类别。
在这里插入图片描述
(2)关系表(字段名、数据类型、长度、约束、说明)
用户表

分类表

注:为classnum设置触发器。原因:classnum格式为字符串不能直接使用自动增长,且格式一定为CN+’三位数字’;而且在实际操作中并不会对分类的内置编号进行操作,即对外是透明的,这就需要系统自己对编号进行维护。作用:实现在规定格式上的自动增长。

图书表
在这里插入图片描述

2、界面设计
a) 刚进入系统的登录界面。
在这里插入图片描述
b) 注册界面
在这里插入图片描述
c) 系统首页。
菜单栏可以在首页和分类管理页面进行切换。中间是输入书号进行查询的精确查询功能。下方可以点击‘查找图书’对所有图书进行模糊查询。点击添加图书,进行图书的添加。

在这里插入图片描述
d) 对分类的管理页面。
中间的主题部分展示所有的分类,下面是对分类的一些操作,将选中的全部取消;输入分类名后点击添加;删除所有选中的分类。

在这里插入图片描述
g) 模糊查询页面
在上面输入或选择查询方式,点击查询。在多个框中输入,按第一个功能进行查询。
选中列表中的数据后才可以进行下面的查看,修改删除操作。

在这里插入图片描述
f) 书籍详细信息页面
在这里插入图片描述
e) 添加页面(修改页面和添加页面样式相同)
在这里插入图片描述

T_classnum触发器(上面提到的设置分类编号自增的触发器)
CREATE
TRIGGER T_classnum BEFORE INSERT ON classify
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)。

  • 6
    点赞
  • 39
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

脸是真的白

如果对你有用的话,可以支持一下

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值