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


Logo

为武汉地区的开发者提供学习、交流和合作的平台。社区聚集了众多技术爱好者和专业人士,涵盖了多个领域,包括人工智能、大数据、云计算、区块链等。社区定期举办技术分享、培训和活动,为开发者提供更多的学习和交流机会。

更多推荐