图书借阅系统-mysql数据库课程设计
通过对图书管理流程的分析,系统应该实现以下功能:图书管理员可以维护图书信息,包括增加新书、修改图书信息、办理图书借阅登记、图书归还登记、过期图书处理、丢失图书处理及读者借阅证件信息的维护等;图书信息具体包括图书编号、图书名称、图书类型、作者、出版社、价格等,其中图书类型将由图书分类号进行说明,每个图书分类号对应一种图书类型。分析图书借阅系统的需求,对现实世界中的图书管理人员中涉及的人,物,事进行抽
1背景及意义
各个城市,各所学校及很多企业事业单位都有见图书馆,收藏了丰富的图书资料,可以供多种需求的读者借阅,实现资源共享。图书馆的图书信息,读者信息及图书借阅管理等是一项非常繁琐但极其重要的工作。传统的图书馆采用人工管理的方式,不仅工作繁琐而且效率低下,因此现在这项工作一般采用数据库系统代替传统的人工管理的方式。图书借阅系统可以有效的管理图书资料信息,控制图书资料的借阅过程,对提高图书馆或阅览室的管理效率有很大的帮助。
2.需求分析
图书管理系统需要解决以往手工管理的种种弊端,比如管理员不能及时地更新图书信息不能及时了解馆藏图书的种类和库存量,也不能掌握读者的借阅情况、超期借阅图书情况等信息。通过对图书管理流程的分析,系统应该实现以下功能:图书管理员可以维护图书信息,包括增加新书、修改图书信息、办理图书借阅登记、图书归还登记、过期图书处理、丢失图书处理及读者借阅证件信息的维护等;而读者可以实现借书、还书、查阅图书信息、查询借书信息等。具体要求如下所示。
图书信息管理:录入各种图书信息、维护图书信息等。图书信息具体包括图书编号、图书名称、图书类型、作者、出版社、价格等,其中图书类型将由图书分类号进行说明,每个图书分类号对应一种图书类型。
读者信息管理:维护读者信息,并根据实际情况的需要修改、更新或删除读者信息。读者信息包括证件号、姓名、证件状态(包括有效和失效)、联系方式等。
借阅管理:包括借书、还书、过期图书归还处理等。借书时登记借阅时间,还书时登记归还时间,并检查借阅时间是否超期,以及进行相应的处理。
图书管理系统主要有如下三种用户。
1)系统管理员:拥有系统的最高权限,可设置图书管理员等。
2)图书管理员:维护图书的基本数据,包括图书种类处理、更新图书信息,进行读者的图书借阅和归还处理等。
3)读者:可以查阅图书信息、借阅图书。
图书馆的图书情况和管理规定如下:每种图书类型都包括很多本不同的图书,同样的图
书可以购买多本;每本图书可以被多次借阅;每位读者可以借阅多本图书;每本图书的借阅
期限是一个月。
3.概念结构设计
分析图书借阅系统的需求,对现实世界中的图书管理人员中涉及的人,物,事进行抽象,从而得到系统的实体,实体的属性,实体的码,实体之间的联系及联系的类型,并用E-R图进行表示。
概念结构设计一般分为三个步骤:
1.确定实体
2.确定关系
3.确定实体的属性和码
3.1抽象出系统的实体
3.2设计初步E-R图
3.3设计全局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
为武汉地区的开发者提供学习、交流和合作的平台。社区聚集了众多技术爱好者和专业人士,涵盖了多个领域,包括人工智能、大数据、云计算、区块链等。社区定期举办技术分享、培训和活动,为开发者提供更多的学习和交流机会。
更多推荐
所有评论(0)