数据库课程计划设计图书治理系统.doc
#*数据库系统原理课程设计数据库系统原理课程设计课题名称:课题名称:图书信息管理系统图书信息管理系统 姓姓 名:名: 班班 级:级: 学学 号:号: 指导老师:指导老师: 2014 年 01 月 02 日#*目录目录1.1.绪论绪论-3 31.11.1 背景介绍背景介绍 -3 1.21.2 开发背景的选用及介绍开发背景的选用及介绍 -32.2.需求分析需求分析-4 42.12.1 系统分析系统分析 -4 2.22.2 系统目标系统目标 -4 2.32.3 总体需求总体需求 -43.3.概念设计阶段概念设计阶段-5 53.13.1 实体实体 E-RE-R 图图 -5 3.23.2 数据流程图数据流程图 -84.4.逻辑结构设计阶段逻辑结构设计阶段-8 84.14.1 E-RE-R 图转换为关系模型图转换为关系模型-8 4.24.2 数据字典数据字典 -95 5物理结构设计阶段物理结构设计阶段-10105.15.1 物理设计阶段的目标和任务物理设计阶段的目标和任务 -10 5.25.2 数据存储方面数据存储方面 -106.6.数据库实施与维护数据库实施与维护-10106.16.1 创建数据库,数据表创建数据库,数据表 -10 6.26.2 创建视图创建视图 -12 6.36.3 创建索引创建索引 -13 6.46.4 创建触发器创建触发器 -13 6.56.5 数据表的初始化数据表的初始化 -14 6.66.6 初始表的显示初始表的显示 -167 7数据库界面实现数据库界面实现-19197.17.1 系统总的功能模块图系统总的功能模块图 -19 7.27.2 系统的实现系统的实现 -198.8.心得体会心得体会-2525#*1.1.绪论绪论1.11.1 背景介绍背景介绍随着社会的发展,人们对于知识的需求也在不断地增长。书籍作为人们获取并增长知 识的主要途径,使得图书馆在人们生活中占有了一定位置。但是近几年来,随着书量的不 断增长,造成了书库空间极度不足,图书挤压,管理不善。这些都直接影响了读者对图书 馆藏书的充分利用。这时图书馆就特别需要开发一套书刊租借管理系统,通过该系统来提 高图书馆的管理效率,从而减少管理方面的工作流和成本。 一个现代化的图书馆在正常运营中总是面对大量的读者信息,书籍信息以及两者相互 作用产生的借书信息,还书信息。面对图书馆数以万计的图书,纷繁复杂的读者信息,频 繁更替的借还书信息,传统的直接方法不但管理出现漏洞,造成损失。因此有一个智能化、 系统化、信息化的图书管理系统十分重要的。充分利用计算机的功能实现对读者管理、书 籍管理,借阅管理等自动化控制,将会使图书馆的工作大大减弱。方便友好的图形界面、 简便的操作、完善的数据库管理。将会使得图书馆系统极大限度的应用于现代化图书管理 中。1.21.2 开发背景的选用及介绍开发背景的选用及介绍1.2.11.2.1 SQLSQL ServerServer 20052005 的简介的简介 SQL 是英文(Structured Query Language)的缩写,意思为结构化查询语言。SQL 语 言的主要功能就是同各种数据库建立联系,进行沟通。SQL 被作为关系型数据库管理系统 的标准语言。SQL 语句可以用来执行各种各样的操作,例如更新数据库中的数据,从数据 库中提取数据等。目前,绝大多数流行的关系型数据库管理系统,如 Oracle, Sybase, Microsoft SQL Server, Access 等都采用了 SQL 语言标准。 SQL 语言有以下几个优点: 1. 非过程化语言 SQL 是一个非过程化的语言,因为它一次处理一个记录,对数据提供自动导航。SQL 允 许用户在高层的数据结构上工作,而不对单个记录进行操作,可操作记录集,所有 SQL 语 句接受集合作为输入,返回集合作为输出。SQL 的集合特性允许一条 SQL 语句的结果作为 另 一条 SQL 语句的输入。 SQL 不要求用户指定对数据的存放方法, 这种特性使用户更易集中精力于要得到的结 果; 所有 SQL 语句使用查询优化器,它是 RDBMS 的一部分,由它决定对指定数据存取的最快速 度的手段,查询优化器知道存在什么索引,在哪儿使用索引合适,而用户则从不需要知道 表 是否有索引、有什么类型的索引。 2. 统一的语言SQL 可用于所有用户的 DB 活动模型,包括系统管理员、数据库管理员、 应用程序员、 决策支持系统人员及许多其它类型的终端用户。基本的 SQL 命令只需很少时间就能学会, 最高级的命令在几天内便可掌握。 3. 所有关系数据库的公共语言由于所有主要的关系数据库管理系统都支持 SQL 语言,用户可将使用 SQL 的技能从一个 RDBMS(关系数据库管理系统)转到另一个,所有用 SQL 编写的程序都是可以移植的。#*1.2.21.2.2 javajava 简介简介 java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的 Java 程序设计语言和 Java 平台(即 JavaSE, JavaEE, JavaME)的总称。Java 技术具有卓越的通用性、高效性、平台移植性和安全性, 广泛应 4 用于个人 PC、数据中心、游戏控制台、科学超级计算机、移动电话和互联网,同 时拥有全球最大的开发者专业社群。在全球云计算和移动互联网的产业环境下,Java 更具 备了显著优势和广阔前景。2.2.需求分析需求分析2.12.1 系统分析系统分析书刊租借系统(以高校的图书管理系统为例)是典型的信息管理系统,其开发主要包括 后台数据库的建立和维护以及前端应用程序的开发两个方面。对于前者要求建立起数据一 致性和完整性强、数据安全性好的数据库。而对于后者则要求应用程序功能完备,易使用等 特点。 在数据库应用系统开发之前,对开发数据库的基本概念,数据库的结构、开发数据库 应用程序的步骤、开发体系及方法都应当有相当清晰的了解和认识。数据库应用系统开发 的目标是建立一个满足用户长期需求的产品。开发的主要过程为:理解用户的需求,然后, 把它们转变为有效的数据库设计。把设计转变为实际的数据库,并且这些数据库带有功能 完备、高效能的应用。2.22.2 系统目标系统目标1.用户方便进行图书查询,图书浏览和图书分类浏览,进行图书借阅并了解自己的借书 情况和个人情况。 2.用户在借书超期的情况下得到来自管理员的提醒。 3.管理员可以方便进行图书管理,用户管理,管理员管理。图书管理包括图书信息以及 图书分类的添加,修改,删除。用户管理包括用户信息的添加,删除,修改和锁定 (限制用户的正常使用功能,使其无法登陆) 。管理员管理包括管理员信息的添加,删 除,修改等。 4.用户和管理员可以修改自己的密码,修改前需先核实自己的原始密码。 5.未注册用户读者也可以浏览所有的图书信息和分类信息,但是无法借阅。 6.考虑程序执行操作时可能出现的情况,比如删除图书分类时该分类下存在图书,程序 自动跳转该分类图书查看。删除某个用户,如果存在借书记录则不允许删除,跳转到 该用户的借书记录。等待管理员确认该用户所借图书已经全部归还之后才允许删除该 用户信息。2.32.3 总体需求总体需求书刊租借系统(以高校图书馆为例)是一项复杂系统工程,要从实际出发,对实际情 况进行客观的分析,深入了解需求。系统利用 java 与数据库结合的技术建立数据库管理系 统,采用交互式的图形用户界面(GUI)来实现。需求调查是为了研究系统设计的开发途径 和方法。同时它也是进行概要设计和详细设计的基础,是进行内部维护和测试的依据。 具体分析如下: 添加操作:在执行操作时首先都要先检查是否已经输入以及数据库中是否已经存在输 入的数据,如果存在会报错,程序返回上个页面,不执行添加操作。#*删除操作:考虑到了字段在不同表中可能会同时存在的情况,比如:删除图书分类时 候该分类下有书或者删除用户时该用户有借书记录,这样的情况下程序会给出提醒并跳转 到该分类下的所有图书查看或者是该用户的全部借书查看。直到这种关联取消掉之后才允 许进行 删除这样的危险操作。 查询操作:考虑到了模糊查询的实现, SQL 语句中用“like” ,还有组合查询,通过 对用户输入情况的判断来确定 SQL 语句的最终形式,比如用户查询时并未输入图书名字, 就是名字匹配任意字符,那么程序给数据库的 SQL 语句就会是 name like % 。组合查询 的实现也是程序判断用户所做的选择或者输入,在 SQL 语句中实现的。 超期统计:假定借书超期的限制是三十天,借书记录中的所有数据的借书时间如果不 在当前服务器时间减去三十天和当前服务器时间之间,那么这条借书记录就属于超期记录 了。由用户借书记录中的用户编号到用户表中查找该用户。 发送消息:往消息表中添加数据,该数据包含用户名,用户超期的图书,超期时间, 罚金等相关警告信息。当用户正常登陆主页后,程序自动检查消息表中是否存在该用户的 记录,如果有要给出提示,但是没有强制用户必须查看。 数据库备份和还原操作:程序只要告诉 SQL 服务器执行备份和还原 SQL 语句就可以实 现,在还原时程序还在使用系统数据库,此时执行还原操作会因为没有排它使用权出现错 误,所以应告诉 SQL 服务器使用另外的一个数据库,程序中用的是:use master。还原操 作时用 FSO 组件首先检查备份数据库文件是否存在,如果不存在则给出提示回到上个页面。 所有条件都允许后则执行还原操作,如果数据库数据比较多,备份和还原的时间都可能会 比较长。3.3.概念设计阶段概念设计阶段3.13.1 实体实体 E-RE-R 图图书刊租借系统有书籍类别实体,书籍实体,读者实体,还书记录实体,借书记录实体, 罚款金额实体等。 3 31.11.1 书籍种类实体书籍种类实体 E-RE-R 图图3.1.23.1.2 书籍实体书籍实体 E-RE-R 图图书籍种类种类编号种类名称书籍书籍编号书籍名称书籍种类单价出版社作者借阅情况#*3.1.33.1.3 读者实体读者实体 E-RE-R 图图3.1.43.1.4 借书记录实体借书记录实体 E-RE-R 图图3.1.43.1.4 还书记录实体还书记录实体 E-RE-R 图图出版日期读者借书证号姓名性别注册日期读者类别借书记录姓名书籍编号书籍名称应还时间借阅时间借书证号还书记录姓名书籍编号借书证号#*3.1.43.1.4 还书记录实体还书记录实体 E-RE-R 图图3.1.53.1.5 总的总的 E-RE-R 图(略去实体属性)图(略去实体属性)归还时间 借阅时 间书籍名称罚款信息书籍编号借书证号姓名书籍名称超期时间罚款金额还书记录归还读者罚款罚款信息书籍借阅借书记录信息登记书籍种类#*3.23.2 数据流程图数据流程图图书馆管理员还书记录借书记录图书归还处理检查读者身份检查图书是否可借填写借阅库,修改图书 库借阅库图书库借阅库图书库填写归还记录修改图书记录有效可借填写借阅记录借阅信息修改4.4.逻辑结构设计阶段逻辑结构设计阶段4.14.1 E-RE-R 图转换为关系模型图转换为关系模型#*书籍种类(种类编号,种类名称) 书籍(书籍编号,书籍名称,书籍种类,作者,出版社,出版时间,单价,是否可借)读者(借书证号,姓名,性别,读者类别,注册日期) 借书记录(姓名,书籍编号,书籍名称,借书证号,借阅时间,应还时间) 还书记录(姓名,书籍编号,书籍名称,借书证号,借阅时间,归还时间) 罚款信息(书籍编号,书籍名称,借书证号,姓名,超期时间,罚款金额)4.24.2 数据字典数据字典表 4-2-1 书籍种类信息表表 4-2-2 书籍信息表表 4-2-3 读者种类信息表表 4-2-4 借书记录信息表表 4-2-5 还书记录信息表表中列名数据类型及长度可否为空种类编号intNot null 种类名称Varchar(30)Not null表中列名数据种类及长度可否为空书籍编号Varchar(20)Not null 书籍名称Varchar(30)Not null 书籍种类Varchar(30)Not null 作者Char(30)Not null 出版社Varchar(30)Null 出版日期DatetimeNull 单价MoneyNot null 是否可借Varchar(20)Not null表中列名数据种类及长度可否为空借书证号IntNot null 姓名Varchar(10)Nou null 性别Char(2)null 读者类别Varchar(20)Null 注册日期DatetimeNot null表中列名数据种类及长度可否为空姓名Varchar(10)Not null 书籍编号Varchar(20)Not null 书籍名称Varchar(30)Not null 借书证号IntNot null 借阅时间DatetimeNot null 应还时间datetimeNot null#*表 4-2-6 罚款信息表5 5物理结构设计阶段物理结构设计阶段5.15.1 物理设计阶段的目标和任务物理设计阶段的目标和任务数据库的物理设计就是为逻辑数据模型选取一个最合适应用要求的物理结构的过程, 在 这个阶段中要完成两大任务: 1) 确定数据库的物理结构,在关系数据库中主要是存取方法和存储结构; 2) 对物理结构进行评价,评价的重点是时间和空间效率。5.25.2 数据存储方面数据存储方面为数据库中各基本表建立的索引如下: 1)由于基本表 readers_table,books_table 的主码借书证号,书籍编号经常在查询 条件和连接操作的连接条件中出现,且它们的值唯一,在两个属性上建立唯一性 索引; 2)借阅信息基本表 borrow_record_table 的一属性借书证号,书籍编号,经常在查 询条件中出现,考虑在其之上建立聚簇索引; 3)还书信息基本表 return_record_table 的一属性借书证号,书籍编号,经常在查 询条件中出现,考虑在其之上建立聚簇索引;6.6.数据库实施与维护数据库实施与维护6.16.1 创建数据库,数据表创建数据库,数据表6.1.16.1.1 创建创建libarysystemlibarysystem数据库数据库表中列名数据种类及长度可否为空姓名Varchar(10)Not null 书籍编号Varchar(20)Not null 书籍名称Varchar(30)Not null 借书证号IntNot null 借阅时间DatetimeNot null 归还时间datetimeNot null表中列名数据种类及长度可否为空书籍编号Varchar(20)Not null 借书证号IntNot null 姓名Varchar(10)Not null 书籍名称Varchar(30)Not null 超期时间IntNot null 罚款金额MoneyNot null#*create database libarysystem on primary ( name=libarysystem_data, size=10, maxsize=50, filename=“D:booklibarysystem_mdf“, filegrowth=10% ) log on ( name=libarysystem_log, size=10MB, maxsize=50MB, filename=“D:booklibarysystem_ldf“, filegrowth=10MB )6.1.26.1.2 创建创建books_stytle_tablebooks_stytle_table表表 create table books_stytle_table ( 种类编号 int primary key, 种类名称 varchar(30) not null )6.1.36.1.3 创建创建readers_tablereaders_table表表 Create table readers_table ( 借书证号 int primary key, 姓名 varchar(10) not null, 性别 char(2) default'男', 读者类别 varchar(20) null, 注册日期 Datetime not null )6.1.46.1.4 创建创建books_tablebooks_table表表 Create table books_table ( 书籍编号 varchar(20) primary key, 书籍名称 varchar(30) not null, 作者 char(30) not null, 出版社 varchar(30) null, 出版日期 Datetime null, 单价 Money not null,#*借阅情况 varchar(20) not null )6.1.56.1.5 创建创建borrow_record_tableborrow_record_table表表create table borrow_record_table ( 姓名 varchar(10) not null, 书籍编号 varchar(20) not null, 书籍名称 varchar(30) not null, 借书证号 int not null, 借阅时间 Datetime not null, 应还时间 Datetime not null, foreign key(书籍编号) references books_table(书籍编号), foreign key(借书证号) references readers_table(借书证号) )6.1.66.1.6 创建创建return_record_tablereturn_record_table表表 Create table return_record_table ( 姓名 varchar(10) not null 书籍编号 varchar(20) not null, 书籍名称 varchar(30) not null 借书证号 int not null, 借阅时间 Datetime not null, foreign key(书籍编号) references books_table(书籍编号), foreign key(借书证号) references readers_table(借书证号) )6.1.76.1.7 创建创建reader_fee_tablereader_fee_table表表 Create table reader_fee_table ( 书籍编号 varchar(20) not null, 借书证号 int not null, 姓名 varchar(10) not null, 书籍名称 varchar(30) not null, 超期时间 int not null, 罚款金额 Money not null, foreign key(书籍编号) references books_table(书籍编号), foreign key(借书证号) references readers_table(借书证号) )6.26.2 创建视图创建视图#*6.2.16.2.1 用于查询图书基本信息的视图定义如下:用于查询图书基本信息的视图定义如下: create view Bookview (借阅证号, 书籍编号, 作者, 出版社, 借阅情况) as Select 借阅证号, 书籍编号, 作者, 出版社, 借阅情况 from books_table6.2.26.2.2 用于读者基本信息查询的视图定义如下:用于读者基本信息查询的视图定义如下: create view Readerview (姓名,j借书证号,注册日期) as select 姓名,借书证号,注册日期 from readers_table6.2.36.2.3 用于显示当前借阅基本信息的视图定义如下:用于显示当前借阅基本信息的视图定义如下: create view Borrowview (借书证号,书籍名称,作者,借阅日期,应还日期) as select borrow_record_table.借书证号, borrow_record_table.书籍名称,作者,借阅日期,应 还日期 from borrow_record_table,books_table where borrow.record_table.书籍编号=books_table. 书籍编号6.2.46.2.4 用于借阅历史信息查询的视图定义如下:用于借阅历史信息查询的视图定义如下: create view Historyview (借书证号,书籍名称,借阅日期,归还日期) as select 借书证号,书籍名称,借阅日期,归还日期 from return_record_table6.2.56.2.5 用于查询罚款信息的视图定义如下:用于查询罚款信息的视图定义如下: create view Fineview (姓名,书籍名称,超期时间,罚款金额) as select 姓名,书籍名称,超期时间,罚款金额 from reader_fee_table6.36.3 创建索引创建索引create unique index readersindex on readers_table(借书证号) create unique index booksindex on books_table(书籍编号) create unique index index1 on borrow_record_table(借书证号,书籍编号) create unique index index2 on return_record_table(借书证号,书籍编号)6.46.4 创建触发器创建触发器6.4.16.4.1 当删除当删除readers_table表中某一读者基本信息时,触发表中某一读者基本信息时,触发borrow_record_table表,删表,删 除相应的记录除相应的记录 create trigger Reader_delete#*on readers_table for delete as declare zhao int; select zhao=借书证号 from deleted delete borrow_record_table where 借书证号=zhao6.4.26.4.2 当在当在 borrow_record_table 表中增加一条借阅记录时,使该图书的状态由中增加一条借阅记录时,使该图书的状态由“可借可借” 变为变为“不可借不可借” create trigger Borrow_insert1 on borrow_record_table for insert as declare BookID char(20); select BookID=书籍编号 from inserted update books_table set 借阅情况='不可借' where 书籍编号=BookID6.56.5 数据表的初始化数据表的初始化6.5.1 books_stytle_table表的初始化表的初始化 Insert into books_stytle_table values(1,'人文艺术类') Insert into books_stytle_table values(2,'自然科学类') Insert into books_stytle_table values(3,'工程技术类') insert into books_stytle_table values(4,'文学类') insert into books_stytle_table values(5,'政治经济类') insert into books_stytle_table values(6,'社会科学类') insert into books_stytle_table values(7,'语言技能类')6.5.2 books_table表的初始化表的初始化 Insert into books_table(书籍编号,书籍名称,书籍种类,作者,出版社,出版日期,单价,借 阅情况) values('A1001','中国大历史','人文艺术类','黄仁宇','人民文学出版社','2007-02-01','32','可 借') insert into books_table(书籍编号,书籍名称,书籍种类,作者,出版社,出版日期,单价,借 阅情况) values('A1002','中国近现代史纲要','人文艺术类','','高等教育出版社','2006-04-01','32','可 借' insert into books_table(书籍编号,书籍名称,书籍种类,作者,出版社,出版日期,单价,借 阅情况)#*values('B1001','计算机操作系统','自然科学类','汤小丹,梁红兵等','西安电子大学出版社 ','2001-04-12','32','不可借') insert into books_table(书籍编号,书籍名称,书籍种类,作者,出版社,出版日期,单价,借 阅情况) values('B1002','计算机网络','自然科学类','谢希仁','电子工业出版社','2003-04-01','32','可 借') insert into books_table(书籍编号,书籍名称,书籍种类,作者,出版社,出版日期,单价,借 阅情况)values('B1003','计算机网络','自然科学类','谢希仁','电子工业出版社','2003-04-01','32','不 可借')insert into books_table(书籍编号,书籍名称,书籍种类,作者,出版社,出版日期,单价,借 阅情况) values('C1001','线性代数','工程技术类','','高等教育出版社','2004-07-01','12.00','可借') insert into books_table(书籍编号,书籍名称,书籍种类,作者,出版社,出版日期,单价,借 阅情况) values('C1002','计算方法','工程技术类','李信真,车刚明等','西北工业大学出版社','2001- 09-01','12.00','可借') insert into books_table(书籍编号,书籍名称,书籍种类,作者,出版社,出版日期,单价,借 阅情况) values('D1001','百年孤独','文学类','马尔克斯著,闫瑞译','北京燕山出版社','2013-02- 14','49.00','可借') insert into books_table(书籍编号,书籍名称,书籍种类,作者,出版社,出版日期,单价,借 阅情况) values('D1002','分成两半的伯爵','文学类','卡尔维诺著,吴正仪译','译林出版社','2002-06- 14','20.00','不可借') insert into books_table(书籍编号,书籍名称,书籍种类,作者,出版社,出版日期,单价,借 阅情况) values('E1001','当代世界经济与政治','政治经济类','李景治','中国人民大学出版社','2002- 06-16','16.00','可借') insert into books_table(书籍编号,书籍名称,书籍种类,作者,出版社,出版日期,单价,借 阅情况) values('E1002','经济学原理','政治经济类','高鸿业','中国人民大学出版社','2002-06- 01','16.00','可借') insert into books_table(书籍编号,书籍名称,书籍种类,作者,出版社,出版日期,单价,借 阅情况) values('F1001','马克思主义基本原理概论','社会科学类','','高等教育出版社','2001-06- 01','17.00','可借') insert into books_table(书籍编号,书籍名称,书籍种类,作者,出版社,出版日期,单价,借 阅情况) values('F1002','思想道德修养与法律基础','社会科学类','','高等教育出版社','2002-09- 01','15.50','可借') insert into books_table(书籍编号,书籍名称,书籍种类,作者,出版社,出版日期,单价,借#*阅情况) values('G1001','大学英语','语言技能类','郑树棠','外语教学与研究出版社','2003-04- 01','15.50','可借') insert into books_table(书籍编号,书籍名称,书籍种类,作者,出版社,出版日期,单价,借 阅情况) values('G1002','大学英语','语言技能类','郑树棠','外语教学与研究出版社','2003-04- 01','15.50','可借')6.5.3 readers_table表的初始化表的初始化 insert into readers_table(借书证号,姓名,性别,读者类别,注册日期) values('31100','王鑫','男','学生','2007-01-01') insert into readers_table(借书证号,姓名,性别,读者类别,注册日期) values('31102','王永胜','男','学生','2008-01-01') insert into readers_table(借书证号,姓名,性别,读者类别,注册日期) values('31101','张倩','女','学生','