图书管理系统数据库设计_第1页
图书管理系统数据库设计_第2页
图书管理系统数据库设计_第3页
图书管理系统数据库设计_第4页
图书管理系统数据库设计_第5页
已阅读5页,还剩9页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、精选优质文档-倾情为你奉上目 录2.3数据流程. .24.概念模型设计.47.1管理员操作.117.2读者操作. .127.3管理员对借阅关系的操作. . 128.专心-专注-专业1.开发背景数据库技术和Internet的飞速发展,使它们已经成为现代信息技术的重要组成部分,是现在计算机信息系统和计算机应用系统的基础和核心。对于任何一个企业来说,数据是企业重要的资产,如何有效利用这些数据,对于企业发展起着极其重要的作用。随着我国市场经济的迅速发展和人们生活水平的不断提高,图书馆藏书的树木逐渐增大,这也挑战了图书管理方面的技术,以前的人工管理方式已经不再适应现在的环境,取而代之的是先进的图书管理系

2、统,通过使用PowerBuilder创建的图书管理系统可以让管理人员方便而快捷的进行管理、查询、借阅、录入等工作。2.需求分析2.1系统目标图书管理信息系统是典型的信息管理系统(MIS),其开发主要包括后台数据库的建立和维护以及前端应用程序的开发两个方面。对于前者要求建立起数据一致性和完整性强.数据安全性好的库。而对于后者则要求应用程序功能完备,易使用等特点。系统开发的总体任务是实现各种信息的系统化,规范化和自动化。2.2需求定义图书馆管理系统开发。系统开发的总的设计目标是实现图书管理的系统化、规范化和自动化,实现对图书资料的集中统一的管理。本系统主要实现对图书馆信息的管理,主要功能为管理有关

3、读者、图书、借阅、查询、删除和管理员的信息等。本系统结构分为读者类别管理、读者档案管理、图书类型管理、图书档案管理以及图书流程管理,读者管理可以浏览读者的信息,可以对读者信息进行维护。图书管理可以浏览图书的信息,可以对图书信息进行维护。借阅管理可以显示当前数据库中书籍借阅情况,可以对借阅信息进行维护。本系统主要解决的问题是利用关键字对数据库进行查询。其系统的功能模块图如下:图书管理系统图书管理图书资料投诉管理系统管理图书赔偿用户管理密码管理退出系统图书借阅图书登记图2-1 系统功能模块图针对一般图书管理信息系统的需求,通过对图书管理工作过程的内容和数据流程分析,设计如下面所示的数据项: 读者信

4、息 属性:读者学号,读者姓名,读者性别,联系电话,所在院系,生效日期,失效日期,违章状况,累计借书 主键:读者学号 书籍信息 属性:ISBN,书名,作者,出版社,出版日期,简介 主键:ISBN 管理员信息 属性:工作号,姓名,性别,电话,家庭住址 主键:工作号 2.3数据流程2.3.1 读者作为学生对图书管理系统的要求有:1. 能按各种方式(比如书名、编号、作者)查询图书馆的藏书情况。2. 能够方便地借阅图书、续借图书、归还图书。3. 能够查询自己的基本资料、借阅图书情况。4. 能够熟悉图书管理系统的使用。读者进入系统工作的流程图为:查询修改密码借阅续借归还注册注销 2-1进入系统工作的流程图

5、2.3.2 图书管理员作为图书管理员,他们对图书管理系统的要求有:1. 能方便的对图书进行录入登记,注销陈旧的书籍。2. 能够方便地对新生进行登记,或注销已经毕业的学生信息(基本信息,借阅信息)。3. 能够随时发布一些诸如各学院学生借阅图书超期情况、馆内藏书情况、借情况等信息,以便各学院能够随时获知本院学生的一些借书信息。图书管理员工作的流程图为:图书登记注册录入修改个人信息注销超期处理2-2图书管理员工作流程图3.功能描述系统功能分析是在系统开发的总体任务的基础上完成。本系统需要完成的功能主要有5部分:(1) 图书基本情况的录入,修改,删除等基本操作。1书籍类别标准的制定,类别信息的输入,包

6、括类别编号,类别名称,关键词,备注信息等。2书籍类别信息的查询,修改,包括类别编号,类别名称,关键词,备注信息等。3书籍信息的输入,包括书籍编号,书籍名称,书籍类别,作者名称,出版社名称,出版日期,书籍页数,关键词,登记日期,备注信息等。(2) 办理借书卡模块。1新生办理借书证。2丢失办理借书证。(3) 实现借书功能。1借书信息的输入,包括借书信息编号,读书编号,读者姓名,书籍编号,书籍名称,借书日期,备注信息等。2借书信息的查询,修改,包括借书信息编号,读者编号,读者姓名,书籍编号,书籍名称,借书日期,备注信息等。(4) 实现还书功能。1还书信息的输入,包括还书信息编号,读者编号,读者姓名,

7、书籍编号,书籍名称,借书日期,还书日期,备注信息等。2还书信息的查询和修改,包括还书信息编号,读书编号,读者姓名,书籍编号,书籍名称,借书日期,还书日期,备注信息等。(5) 能方便的对图书进行查询。对超期的情况能自动给出提示信息4.概念模型设计各部分E-R图如下:(1)读者信息类别实体E-R图读者编号借书期限借书数量种类名称读者类别实体4-1 读者类别实体E-R图(2)书籍信息类别实体E-R图图书编号书籍类别出版社书籍名称书籍类别实体4-2 书籍类别实体E-R图(3)图书借阅实体E-R图:图书借阅实体借阅编号书籍信息借书日期读者信息4-3 图书借阅实体E-R图(4)投诉管理实体E-R图: 投诉

8、管理实体投诉日期受诉日期投诉内容投诉对象投诉日期4-4 投诉管理实体E-R图投诉读者类别信息图书类别信息读者信息管理书籍信息管理读者登记书籍登记借阅信息管理4-5实体之间关系的E-R图借阅关系(读者、管理员、书籍三元关系)图4-6 CDM图5.逻辑模型设计和优化从理论E-R模型到理论关系模型的整理转换,通过E-R模型到关系模型的转化,可以得到如下关系模式: 借阅关系 属性:工作号,读者学号,ISBN,是否续借,借书日期,还书日期,备注。 主键:工作号,读者学号,ISBN 管理员_书籍关系 属性:工作号,ISBN,添加时间,是否在馆 主键:工作号,ISBN 管理员_学生关系 属性:工作号,读者学

9、号,确认借还 主键:工作号,读者学号通过由概念模型设计得到CDM图powerdesigner转换成对应的PDM图:PDM图5.1图书信息表列名数据类型可否为空ISBNvarchar否书名varchar否作者varchar否出版社varchar是出版日期datetime是简介varchar是5.2 读者信息表列名数据类型可否为空读者学号varchar否读者姓名varchar否读者性别varchar否联系电话varchar是所在院系varchar否5.3 管理员信息表列名数据类型可否为空工作号varchar否姓名varchar否性别varchar否电话varchar是家庭住址varchar是5.4

10、 借阅表 列名数据类型可否为空工作号char否ISBNchar否读者学号char否借阅日期datetime否还书日期datetime否是否续借char否 5.5 管理员_书籍 列名数据类型可否为空工作号char否ISBNchar 否添加时间datatime是是否在馆char是5.6 管理员_学生 列名数据类型可否为空工作号char否读者学号char否借还确认char否6.物理设计和实施 从理论关系模型到实现实施数据库建立,物理文件的安排和建立索引 6.1 建立索引 为了提高在表中搜索元组的速度,在实际实现的时候应该基于键码建立索引是各表中建立索引的表项: (1)读者信息(读者学号)

11、(2)书籍信息(ISBN) (3)管理员信息(工作号) (4)借阅(工作号,读者学号,ISBN) (5)管理员_书籍(工作号,ISBN) (6)管理员_学生(工作号,读者学号) 6.2 SQL语句如下所示:/*=*/* Table: 书籍信息 */*=*/create table 书籍信息 ( ISBN char(20) not null, 书名 char(20), 作者 char(10), 出版社 char(15), 出版日期 char(30), 简介 char(160), constraint PK_书籍信息 primary key (ISBN);/*=*/* Index: 书籍信息_PK

12、 */*=*/create unique index 书籍信息_PK on 书籍信息 (ISBN ASC);/*=*/* Table: 投诉 */*=*/create table 投诉 ( 工作号 char(10) not null, 学号 char(10) not null, 投书意见 char(100), 投诉日期 char(30), 受诉日期 char(30), constraint PK_投诉 primary key (工作号, 学号);/*=*/* Index: 投诉_PK */*=*/create unique index 投诉_PK on 投诉 (工作号 ASC,学号 ASC);

13、/*=*/* Index: 投诉_FK */*=*/create index 投诉_FK on 投诉 (工作号 ASC);/*=*/* Index: 投诉2_FK */*=*/create index 投诉2_FK on 投诉 (学号 ASC);/*=*/* Table: 登记 */*=*/create table 登记 ( 工作号 char(10) not null, 学号 char(10) not null, ISBN char(20) not null, 证书日期 char(30) not null, 还书日期 char(30) not null, 违章状况 char(160), 累计借

14、书 char(160), 备注 char(160), constraint PK_登记 primary key (工作号, 学号, ISBN);/*=*/* Index: 登记_PK */*=*/create unique index 登记_PK on 登记 (工作号 ASC,学号 ASC,ISBN ASC);/*=*/* Index: 登记_FK */*=*/create index 登记_FK on 登记 (工作号 ASC);/*=*/* Index: 登记2_FK */*=*/create index 登记2_FK on 登记 (学号 ASC);/*=*/* Index: 登记3_FK

15、*/*=*/create index 登记3_FK on 登记 (ISBN ASC);/*=*/* Table: 管理员信息 */*=*/create table 管理员信息 ( 工作号 char(10) not null, 姓名 char(10), 性别 char(5), 电话 char(15), 所在院系 char(25), constraint PK_管理员信息 primary key (工作号);/*=*/* Index: 管理员信息_PK */*=*/create unique index 管理员信息_PK on 管理员信息 (工作号 ASC);/*=*/* Table: 读者信息

16、*/*=*/create table 读者信息 ( 学号 char(10) not null, 姓名 char(10), 性别 char(5), 电话 char(15), 所在院系 char(25), constraint PK_读者信息 primary key (学号);/*=*/* Index: 读者信息_PK */*=*/create unique index 读者信息_PK on 读者信息 (学号 ASC);7.主要数据操纵语句 7.1管理员操作 (1)注册(register) INSERT INTO 管理员 (工作号,姓名,性别,电话,家庭住址,备注) VALUES(#工作号,#姓名

17、,#性别,#电话,#家庭住址,#备注) 说明:在登记操作后,管理员得到一个唯一的工作号,可以根据这个工作号采查询和修改数据。 (2)注销(unregister) DELETE FROM Provider WHERE(工作号=#工作号); (3)修改个人信息(update) UPdate 管理员 Set (工作号=#工作号,姓名=#姓名,性别=#性别,电话=#电话,家庭住址=#家庭住址) WHERE(工作号#工作号) (4)增加书籍(addbooks) INSERT INTO 图书 (ISBN,书名,作者,出版社,出版日期,简介,) VALUES(#ISBN,#书名,#作者,#出版社,#出版日期

18、,#简介,#备注) INSERT INTO 管理员_书籍表(工作号,ISBN,添加时间,是否在馆) VALUES(#工作号,#ISBN,#添加时间,#是否在馆) (5)删除书籍(deletebooks) DELETE 图书 WHERE(ISBN =# ISBN) (6)修改书籍(updatebooks) UPDATE 图书(书名=#书名, 作者=#作者, 出版社=#出版社, 出版日期= #出版日期, 简介=#简介) WHERE(ISBN =# ISBN) 7.2读者操作 (1)注册(register) INSERT INTO 读者(读者学号,读者姓名,读者性别,联系电话,所在系, 生效日期,失

19、效日期,违章状况,累计借书,备注) VALUES(#读者学号,#读者姓名,#读者性别,#联系电话,#所在系, #生效日期,#失效日期,#违章状况,#累计借书,#备注) 说明:在登记操作后,读者得到一个唯一的ID,可以根据这个ID来查询和修改自己的信息。 (2)注销(unregister) DELETE 读者 WHERE(读者学号=#读者学号) (3)修改个人信息(update) UPDATE 读者 Set(读者姓名=#读者姓名,联系电话=#联系电话, 所在系=#所在系,生效日期=#生效日期,失效日期=#失效日期, 违章状况=#违章状况,累计借书=#累计借书,备注=#备注) WHERE(读者学号=#读者学号) (4)查询(select) SELECT ISBN,书名,作者,出版社 FROM图书 WHERE ISBN=#ISBN OR书名=#书名 7.3管理员对借阅关系的操作 (1)插入读者的信息(insert) INSERT INTO 借阅(工作号,读者学号,ISBN,是否续借,借书日期,还书日期,备注) VALUES(#工作号,#读者学号,#ISBN,#是否续借,#借书日期, #还书日期,#备注) (2)更新信息(update) 更新借出信息 UPDATE借阅 SET(借书日期=#借书日期,还书日期=借书日期+30,是否续借=0) WHERE(工作号=#工作号 AND

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论