图书借阅系统-mysql数据库课程设计

本文探讨了图书馆图书借阅系统的构建,包括需求分析、概念结构设计(E-R图)、逻辑结构设计(数据库模式)以及物理设计(MySQL数据库创建和管理)。系统需支持图书信息管理、读者信息管理和借阅流程,以提高图书馆管理效率。
摘要由CSDN通过智能技术生成

1背景及意义

各个城市,各所学校及很多企业事业单位都有见图书馆,收藏了丰富的图书资料,可以供多种需求的读者借阅,实现资源共享。图书馆的图书信息,读者信息及图书借阅管理等是一项非常繁琐但极其重要的工作。传统的图书馆采用人工管理的方式,不仅工作繁琐而且效率低下,因此现在这项工作一般采用数据库系统代替传统的人工管理的方式。图书借阅系统可以有效的管理图书资料信息,控制图书资料的借阅过程,对提高图书馆或阅览室的管理效率有很大的帮助。

2.需求分析

图书管理系统需要解决以往手工管理的种种弊端,比如管理员不能及时地更新图书信息不能及时了解馆藏图书的种类和库存量,也不能掌握读者的借阅情况、超期借阅图书情况等信息。通过对图书管理流程的分析,系统应该实现以下功能:图书管理员可以维护图书信息,包括增加新书、修改图书信息、办理图书借阅登记、图书归还登记、过期图书处理、丢失图书处理及读者借阅证件信息的维护等;而读者可以实现借书、还书、查阅图书信息、查询借书信息等。具体要求如下所示。
图书信息管理:录入各种图书信息、维护图书信息等。图书信息具体包括图书编号、图书名称、图书类型、作者、出版社、价格等,其中图书类型将由图书分类号进行说明,每个图书分类号对应一种图书类型。
读者信息管理:维护读者信息,并根据实际情况的需要修改、更新或删除读者信息。读者信息包括证件号、姓名、证件状态(包括有效和失效)、联系方式等。
借阅管理:包括借书、还书、过期图书归还处理等。借书时登记借阅时间,还书时登记归还时间,并检查借阅时间是否超期,以及进行相应的处理。
图书管理系统主要有如下三种用户。
1)系统管理员:拥有系统的最高权限,可设置图书管理员等。
2)图书管理员:维护图书的基本数据,包括图书种类处理、更新图书信息,进行读者的图书借阅和归还处理等。
3)读者:可以查阅图书信息、借阅图书。
图书馆的图书情况和管理规定如下:每种图书类型都包括很多本不同的图书,同样的图
书可以购买多本;每本图书可以被多次借阅;每位读者可以借阅多本图书;每本图书的借阅
期限是一个月。

3.概念结构设计

分析图书借阅系统的需求,对现实世界中的图书管理人员中涉及的人,物,事进行抽象,从而得到系统的实体,实体的属性,实体的码,实体之间的联系及联系的类型,并用E-R图进行表示。

概念结构设计一般分为三个步骤:

        1.确定实体

        2.确定关系

        3.确定实体的属性和码

3.1抽象出系统的实体

图1   图书类型实体及属性

图2  图书实体及属性

图3  读者实体及其属性

3.2设计初步E-R图

图4   标题图书借阅系统初步E-R图

3.3设计全局E-R图

图5   图书借阅系统全局E-R图

4.逻辑结构设计

数据库的逻辑结构设计是根据概念结构设计阶段的全局E-R图,按照转换规则成数据模型的过程。

图书借阅管理的关系模式如下

图书类型(图书分类号,图书分类名称,描述信息)

图书(图书编号,图书名称,图书分类号,作者,出版社,价格)

读者(证件号,姓名,证件状态,联系方式)

借阅(证件号,图书编号,借阅日期,应还日期,归还日期,罚款金)

5.数据库物理设计与实施

5.1使用MySQL创建数据库

5.2建立和管理基本表

5.2.1建立基本表

图书信息表

图书表的属性

属性数据类型是否为空/约束条件
图书编号char(13)

主键

图书名称varchar(50)
图书分类号char(7)
作者char(10)否,外键参照图书类型表
出版社char(30)
价格float必须大于0

SQL语句

CREATE TABLE 图书(

图书编号     CAHR(13) NOT NULL,

图书名称     VARCHAR (50) NOT NULL,

图书分类号 CHAR(7) NOT NULL,

作者            CHAR(10) NOT NULL,

出版社         CHAR (30) NOT NULL,

价格            FLOAT,

CONSTRAINT BOOK_BORROW_FKF1H FOREIGN KEY (图书分类号) REFERENCES

图书类型(图书分类号))

图书类型

图书类型表属性
属性数据类型是否为空/约束主键
图书分类号CHAR(7)主键
图书分类名称CHAR(20)
描述信息VARCHAR(50)

CREATE TABLE 图书类型(

图书分类号 CHAR(7) NOT NULL  PRIMARY KEY,

图书分类名称 CHAR(20)NOT NULL,

描述信息 VARCHAR(50))

  读者

读者表的属性
属性数据类型是否为空/约束条件
证件号CHAR(10)主键
姓名CHAR(8)
证件状态CHAR(4)
联系方式CHAR(11)

CREATE TABLE 读者(

证件号     CHAR(10) NOT NULL PRIMARY KEY,

姓名         CHAR(8) NOT NULL,

证件状态  CHAR(4) NOT NULL CHECK (证件状态 IN ('可用','失效')),

联系方式  CHAR(11))

借阅

借阅表的属性
属性数据类型是否为空/约束条件
证件号CAHR(10)主键
图书编号CHAR(13)主键
借阅日期DATE主键
应还日期DATE
归还日期DATE
罚款金float默认为0.0,>=0.0

CREATE TABLE 借阅(

证件号 CHAR(10) NOT NULL,

图书编号 CHAR(13) NOT NULL,

借阅日期 DATE NOT NULL,

应还日期 DATE NOT NUULL,

归还日期 DATE NOT NULL,

罚款金 FLOAT NOT NULL DEFAULT 0.0 CHECK (罚款金>= 0.0)

CONSTRAINT BOOK_BORROW_PKZJSH PRIMARY KEY ( 证件号,图书编号,借阅日期), 

CONSTRAINT BOOK_BORROW_PKZJSH PRIMARY KEY (证件号),REFERENCES 读书(证件号),

CONSTRAINT BOOK_BORROW_PKZJSH PRIMARY KEY (图书编号),REFERENCES 图书(图书编号))

5.3建立和管理视图

建立计算机图书

CREATE VIEW 计算机图书

AS 

SELECT 图书.*,图书类型。图书分类名称

RROM 图书,图书类型

WHERE 图书.图书分类号=图书类型.图书分类号

AND 图书类型,图书分类名称 LIKE‘计算机%’

读书借书情况表

CREATE VIEW 读书借书情况表(读者证件号,读者姓名,图书名称,结束日期)

AS

SELECT 读者.证件号,读者.姓名,图书.图书名称,借阅.借阅日期

FROM 读者,图书,借阅

WHERE  读者.证件号=借阅.证件号

AND 图书.图书编号=借阅.图书编号

6数据库维护

6.1 使用MySQL语句进行备份

利用MySQL语句创建备份设备

SP_ADDUMPDEVICE ‘disk','图书借阅系统_BAK','url'

利用MySQL语句备份数据库

BACKUP DATABASE 图书借阅系统 TO DISK=’图书借阅系统_BAK'

6.2触发器

触发器是一种保护数据完整性的方法,其创建方法有两种

1利用mysql语句的CREATE TRIGGER进行创建

2 利用management studio 工具交互式创建

例如当向借阅表中插入一条借阅记录,先在读者表中查看是否存在该证件号的读者,若没有,则向借阅表中插入借阅记录就不会成功,并且输出提示信息,没有该读者

CREATE TEIGGER Insert_借阅

ON 借阅

FOR INSERT

AS

IF(SELECT COUN(*)FROM 读者,INSERTED

WHERE 读者.证件号=INSERTED.证件号 )=0

BEGIN

PRINT'没有该读者的信息‘

POLLBACK TRANSACTION

END


  • 26
    点赞
  • 105
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
2.2 主要功能说明: 一.欢迎界面:改界面主要是作为本系统的封面,程序运行后该界面会出 现在屏幕中间,操作者可以点击该界面即可计入下一个窗体。 二.入口:本系统中权限的设置主要是靠入口,选择不同的登录身份进入 系统后将会得到不一样的执行权限。若选择退出系统,则将会退出整个软件。 三. 读者登陆界面:该窗体主要是给一般读者登陆系统执行图书的查询和借阅功能的,当读者输入的编号和密码正确后即可进入系统,当用户输入用户名和密码出现错误后,系统会提示用户重新输入。当用户三次输入均出现错误时,系统会自动关闭。 四.管理员登陆界面:该窗体主要是提供给系统管理员进入系统进行操作的,其中用法和读者登陆界面一样,不同的是进入系统后具有的操作权限不同。管理员具有全部权限。 五.图书管理:(1)图书信息录入界面:此界面主要用于首次录入图书信 息,因此该界面应该具有输入图书所有信息的元素, 如图书编号,书名,书号,作者…. (2)图书信息修改界面:此界面主要是用于已经存在馆里的图书的信息的修改,因此该界面应该有查找和修改的功能,所以除了具有图书信息录入界面的元素外,还应该有上一条,下一条,查询等元素。 六.读者管理:(1)读者注册界面:此界面主要是用于录入新读者的信息, 因此此界面应该具有读者的所有信息,另外应该还具 有赋予读者一个进入系统的密码的元素。 (2)读者信息修改:此界面主要用于对已经注册过本系统 的读者的信息的修改,包括密码等等元素。 七.图书服务:(1)图书查询界面:此界面主要是用于查询,借阅,预 约图书,查询时可按图书的书名,作者,出版社来 查询,查询到的图书用表格显示,并且可以显示图书借阅情况。 (2)借书还书界面:该界面主要是用于读者的借书和还 书的情况,并且读者可以归还图书。 八.数据安全:(1)数据备份界面:该界面主要用于对本系统的重要数 据进行备份,以便不小心失去数据后可以恢复数据 提高系统的安全性。 (2)数据恢复界面:该界面是和数据备份界面配合使用的,当需要恢复已经备份的数据时,即可使用该窗体。 九.系统管理:(1)帮助和相关界面:该界面主要是向使用本系统的读者或者管理员提供相应的提示和帮助,同时显示一些关于本系统的相关信息。 (2)密码设置界面:该界面主要是用于管理员的注册和密码修改,注册界面可以注册新的管理员,密码修改界面可以对已经存在的管理员的信息的修改。 (3)退出本系统界面:该界面主要是用来安全退出整个软件,包括退出了vfp软件 (4)恢复vfp系统界面:该界面主要是用来退出当前运行的图书管理系统,恢复到vfp系统继续进行操作。
该代码文件用于本科生计算机科学与技术专业数据库课程设计图书借阅管理子系统数据库用户名sa,密码gsw,数据库名名称BookManageSystem,这些都可以在DButil.java文件中修改。功能有学生账号注册登录借书还书,罚款计算,同时设有管理员,账号固定在login.Java代码中为administrator,密码password,可自行在代码中修改,管理员可查询图书情况,学生账户情况,修改图书信息等等功能,内容十分简单,十分适合大二大三本科生参考 设计系统模拟学生在图书借阅图书的管理内容,包括查询图书、借书、借阅后的查询、统计、超期罚款等的处理情况,简化的系统需要管理的情况如下: 1、可随时查询出可借阅图书的详细情况,如图书编号(BNO)、图书名称(BNA)、出版日期(BDA)、图书出版社(BPU)、图书存放位置(BPL)、图书总数量(BNU)等,这样便于学生选借。 2、学生查询图书情况后即可借阅所需图书,可借阅多种图书,每种图书一般只借一本,若已有图书超期请交清罚金后,才能开始本次借阅; 3、为了唯一标识每一学生,图书室办借书证需如下信息:学生姓名(SNA)、学生系别(SDE)、学生所学专业(SSP)、借书上限数(SUP)及唯一的借书证号(SNO)。 4、每学生一次可借多本书,但不能超出该生允许借阅上限数,每个学生可多次借阅,允许重复借阅同一本书。规定借书期限为二个月,超期每天罚二分。 5、学生可以进行借阅、续借、归还和查询书籍。借阅时要登记相应的借书日期;归还时要记录还书日期;续借相当于归还书后重新借阅。 根据以上信息完成如下要求: 1、请认真作系统需求分析,设计出反映本系统的E-R图(需求分析、概念设计)。 2、写出已设计E-R图相应的关系模式,根据设计需要还可增加辅助关系模式,并找出各关系模式的关键字(逻辑设计)。 3、在已设计的关系模式基础上开发设计功能子系统,要求子系统能完成如下功能要求(物理设计、设施与试运行): 1)在某数据库管理系统中建立各关系模式对应的库表,并设计所需的视图、索引等。 2)能对各库表进行输入、修改、删除、添加、查询、打印等基本操作。 3)能根据学生要求借阅图书库中有的书,并完成一次借阅任务后汇总已借书本总数,报告还可借书量,已超期的需付清罚款金额后才可借书。 4)能明细查询某学生的借书情况及图书的借出情况。 5)能统计出某图书的总借出数量与库存量及某学生借书总数,当天为止总罚金。 6)其他你认为子系统应有的查询、统计功能。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值