数据库设计关于图书馆管理系统的设计.docx
《数据库设计关于图书馆管理系统的设计.docx》由会员分享,可在线阅读,更多相关《数据库设计关于图书馆管理系统的设计.docx(20页珍藏版)》请在冰豆网上搜索。
![数据库设计关于图书馆管理系统的设计.docx](https://file1.bdocx.com/fileroot1/2022-11/23/fd3e4a45-a965-45f0-9908-0159da72755c/fd3e4a45-a965-45f0-9908-0159da72755c1.gif)
数据库设计关于图书馆管理系统的设计
《数据库系统原理》课程设计
名:
张笑
号:
2013110355
13网工1班
业:
网络工程
级:
1.背景
1.1问题描述1
1.2数据需求1
1.3事物需求2
1.4关系模式2
2.方案图表设计
2.1E-R图2
2.2数据流程图6
2.3数据字典7
2.4关系图9
3.
10
数据库源代码
3.1数据库建立10
3.2数据初始化12
4.结果数据处理15
4.1单表查询15
4.2超期处理17
4.3还书操作17
4.4借书操作19
4.5书籍状态21
4.6读者状态21
5.
结束语24
1.问题描述
AA
1.1背景
随着图书馆规模的不断扩大,图书数量也相应的增加,有关图书的各种信息量也成倍增加,面对着庞大的信息量,传统的人工方式管理会导致图书馆管理上的混乱,人力与物力过多浪费,图书馆管理费用的增加,从而使图书馆的负担过重,影响整个图书馆的运作和控制管理,因此,必须制定一套合理、有效,规范和实用的图书管理系统,对图书资料进行集中统一的管理。
另一方面,IT产业和Internet获得了飞速发展,计算机应用已渗透到了各个领域,引起信息管理的革命,实现了信息的自动化处理,提高了处理的及时性和正确性。
提高图书管理工作效率,作到信息的规范管理,科学统计和快速查询,让图书馆更好的为学校,社会服务。
1.2数据需求
图书馆管理信息系统需要完成功能主要有:
1.读者基本信息的输入,包括借书证编号、读者姓名、读者性别。
2.读者基本信息的查询、修改,包括读者借书证编号、读者姓名、读者性别
等。
3.书籍类别标准的制定、类别信息的输入,包括类别编号、类别名称。
4.书籍类别信息的查询、修改,包括类别编号、类别名称。
5.书籍库存信息的输入,包括书籍编号、书籍名称、书籍类别、作者姓名、出版社名称、出版日期、登记日期。
6.书籍库存信息的查询,修改,包括书籍编号、书籍名称、书籍类别、作者
姓名、出版社名称、出版日期登记日期等。
7.借书信息的输入,包括读者借书证编号、书籍编号、借书日期。
8.借书信息的查询、修改,包括借书证编号、读者编号、读者姓名、书籍编
号、书籍名称、借书日期等。
9.还书信息的输入,包括借书证编号、书籍编号、还书日期。
10.还书信息的查询和修改,包括还书读者借书证编号、读者姓名、书籍编号书籍名称、借书日期、还书日期等。
11.超期还书罚款输入,还书超出期限包括超出期限还书的读者借书证号,书籍编号,罚款金额。
12.超期还书罚款查询,删除,包括读者借书证编号、读者姓名、书籍编号、
书籍名称,罚款金额等
1.3事物需求
(1)在读者信息管理部分,要求:
a.可以查询读者信息。
b.可以对读者信息进行添加及删除的操作。
(2)在书籍信息管理部分,要求:
a.可以浏览书籍信息,要求:
b.可以对书籍信息进行维护,包括添加及删除的操作。
(3)在借阅信息管理部分,要求:
。
a.可以浏览借阅信息。
b.可以对借阅信息进行维护操作。
(4)在归还信息管理部分,要求:
a.可以浏览归还信息
b.对归还信息可修改维护操作
(5)在管理者信息管理部分,要求:
a.显示当前数据库中管理者情况。
b.对管理者信息维护操作。
(6)在罚款信息管理部分,要求:
a.可以浏览罚款信息
b.对罚款信息可以更新
1.4关系模式
(一)书籍类别(种类编号,种类名称)
(二)读者(借书证编号,读者姓名,读者性别,读者种类,登记时期)
(三)书籍(书籍编号,书籍名称,书籍类别,书籍作者,出版社名称,出版日期,登记日期,是否被借出)
(四)借阅(借书证编号,书籍编号,读者借书时间)
(五)还书(借书证编号,书籍编号,读者还书时间)
(六)罚款(书籍名称,读者姓名,借书证编号,罚款金额,借阅时间)以上通过关系代数方法的进行运算得到所需要的结果,在实验结果中可以看到。
2.方案图表设计
2.1E-R图
根据1)所要实现的功能设计,可能建立它们之间的关系,进而实现逻辑结构功能。
图书管理信息系统可以划分的实体有:
书籍类别信息实体、读者信息实体、书籍信息实体、借阅记录信息实体,归还记录信息实体,罚款信息实体。
用E-R图一一描
述这些实体。
2.1.1类别实体E-R图:
图2-1书籍类别实体E-R图
2.1.2读者信息实体E-R图:
2.1.3书籍信息实体E-R图:
2.1.4.借阅记录信息实体E-R图:
图2-3书籍信息实体E-R图
图2-4借阅记录信息实体E-R图
2.1.5归还记录信息实体E-R图:
2.1.6罚款信息实体E-R图:
2.1.6总的信息实体E-R图:
还书信息实体
图2-7总的信息实体E-R图
图2-7系统的数据流程图
2.3数据字典
表2-1booksytle书籍类别信息表
表中列名
数据类型
可否为空
说明
bookstyleno
varchar
notnull(主键)
种类编号
bookstyle
Varchar
notnull
种类名称
表2-2systemreaderS卖者信息表格
表中列名
数据类型
可否为空
说明
readerid
varchar
notnull(主键)
读者借书证号
readername
varchar
notnull
读者姓名
readersex
varchar
notnull
读者性别
readertype
varchar
null
读者种类
regdate
datetime
null
登记日期
表2-3systembook书籍信息表
表中列名
数据类型
可否为空
说明
bookid
Varchar
Notnull(主键)
书籍编号—
bookname
Varchar
Notnull
书籍名称
bookstyle
Varchar
Notnull
书籍类别
bookauthor
Varchar
Notnull
书籍作者
bookpub
Varchar
Null
出版社名称
bookpubdate
Datetime
Null
出版日期
bookindate
Datetime
Null
登记日期—
isborrowed
Varchar
NotNull
是否被借出
表2-4borrowrecord借阅记录信息表
表中列名
数据类型
可否为空
说明
readerid
Varchar
Notnull(外主键)
读者借阅证编号:
bookid
Varchar
Notnull(外主键)
书籍编号
borrowdate
Varchar
Notnull
读者借书时间
表2-5returnrecord借阅记录信息表
表中列名
数据类型
可否为空
说明
readername
Varchar
Notnull(外主键)
读者借阅证编号:
readerid
Varchar
Notnull(外主键)
书籍编号
returndate
datetime
Notnull
读者还书时间
表2-6readerfee罚款记录信息表
readerid
varchar
Notnull
读者借书证编号
readername
varchar
Notnull
读者姓名—
bookid
varchar
Notnull(外主键)
书籍编号J
bookname
varchar
Notnull
书籍名称
bookfee
varchar
NotNull
罚款金额
borrowdate
datetime
NotNull
借阅时间
2.4关系图:
boo^style+
V^Q0k£tyl4D4
bookstyle
system_books丰
tooki4boolmanslockstylenolookinihorboclq^Tibtookpubdatelookindateisborrow&i
TO
rEturn_record
bockidreaderidreterbia
re
ader_fee
systemrEadcrs
readerid.
reid^rid
J
readtrniint
L.rf■
readernane
boolid
rs
booloitiiht
readertyjie
bool:
fe&
re^d^te
borTCwda.tw
图2-8数据库存表关系图
s
borrowrecord
bookid
bturrottdate
3.数据库源代码
3.1数据库建立
3.1.1创建数据库
USEmaster
GO
CREATEDATABASElibrarysystem
ON
(NAME=librarysystem,
FILENAME='d:
\librarysystem.mdf',SIZE=10,
MAXSIZE=50,
FILEGROWTH=5)
LOGON
(NAME='library',
FILENAME='d:
\librarysystem.ldf',SIZE=5MB,
MAXSIZE=25MB,FILEGROWTH=5MB)
GO
3.1.2书本类别表建立
createtablebook_style
(
bookstylenovarchar(30)primarykey,bookstylevarchar(30)
)
3.1.3创建书库表createtablesystem_books
(
bookidvarchar(20)primarykey,booknamevarchar(30)Notnull,bookstylenovarchar(30)Notnull,bookauthorvarchar(30),bookpubvarchar(30),bookpubdatedatetime,bookindatedatetime,isborrowedvarchar
(2),foreignkey(bookstyleno)referencesbook_style(bookstyleno),
3.1.4借书证表建立
createtablesystem_readers
(readeridvarchar(9)primarykey,
readernamevarchar(9)notnull,readersexvarchar
(2)notnull,readertypevarchar(10),regdatedatetime
)
3.1.5借书记录表建立
createtableborrow_record
(bookidvarchar(20)primarykey,
readeridvarchar(9),
borrowdatedatetime,
foreignkey(bookid)referencessystem_books(bookid),foreignkey(readerid)referencessystem_readers(readerid),)
3.1.6还书记录表建立createtablereturn_record(bookidvarchar(20)primarykey,
readeridvarchar(9),
returndatedatetime,
foreignkey(bookid)referencessystem_books(bookid),foreignkey(readerid)referencessystem_readers(readerid))
3.1.7罚款单表建立*/createtablereader_fee(readeridvarchar(9)notnull,
readernamevarchar(9)notnull,
bookidvarchar(20)primarykey,
booknamevarchar(30)Notnull,
bookfeevarchar(30),
borrowdatedatetime,
foreignkey(bookid)referencessystem_books(bookid),foreignkey(readerid)referencessystem_readers(readerid)
3.2数据初始化
3.2.1将书籍类别加入表book_style中
insertintobook_style(bookstyleno,bookstyle)values('1','人文艺术类')insertintobook_style(bookstyleno,bookstyle)values('2','自然科学类')insertintobook_style(bookstyleno,bookstyle)values('3','社会科学类')insertintobook_style(bookstyleno,bookstyle)values('4','图片艺术类')insertintobook_style(bookstyleno,bookstyle)values('5','政治经济类')insertintobook_style(bookstyleno,bookstyle)values('6','工程技术类')insertintobook_style(bookstyleno,bookstyle)values('7','语言技能类')
3.2.2将已有的图书加入system_books表中(定义相同的作者出版社的书本编号不一样)
insert
intosystem_books(bookid,bookname,bookstyleno,bookauthor,bookpub,bookpubdate,bookindate,isborrowed)
values('00125415152','计算机组成原理','6','王爱英','清华大学出版社','2001-01-03','2003-11-15','1');insert
intosystem_books(bookid,bookname,bookstyleno,bookauthor,bookpub,bookpubdate,bookindate,isborrowed)
values('00125415153','计算机组成原理','6','王爱英','清华大学出版社','2001-01-03','2003-11-15','1');insert
intosystem_books(bookid,bookname,bookstyleno,bookauthor,bookpub,bookpubdate,bookindate,isborrowed)
values('00456456','数据库原理','6','萨师煊','高等教育出版社','2007-07-02','2007-09-15','1');insert
intosystem_books(bookid,bookname,bookstyleno,bookauthor,bookpub,bookpubdate,bookindate,isborrowed)
values('12215121','C程序设计','6','谭浩强','清华大学出版社','2002-04-02','2004-03-14','1');insert
intosystem_books(bookid,bookname,bookstyleno,bookauthor,bookpub,bookpubdate,bookindate,isborrowed)
values('9787308020558','计算机体系结构','6','石教英','浙江大学出版社','2004-10-03','2006-11-15','1');
insert
intosystem_books(bookid,bookname,bookstyleno,bookauthor,bookpub,bookpubdate,bookindate,isborrowed)
values('45456141414','数据结构(C语言版)’,'6','吴伟民,严蔚敏','清华大学出版社','2002-06-28','2004-01-21','1');
insert
intosystem_books(bookid,bookname,bookstyleno,bookauthor,bookpub,bookpubdate,bookindate,isborrowed)
values('5455515','中华历史5000年','1','吴强’,北京大学出版社’,'2005-04-03','2006-05-15','1');insert
intosystem_books(bookid,bookname,bookstyleno,bookauthor,bookpub,bookpubdate,bookindate,isborrowed)
values('O15115','古代埃及’,3,'赵文华','北京大学出版社’,'2001-02-02','2002-09-15','1');
insert
intosystem_books(bookid,bookname,bookstyleno,bookauthor,bookpub,bookpubdate,bookindate,isborrowed)
values('1514514','日本文化','1','吴小鹏','北京大学出版社’,'2002-04-02','2004-03-14','1');
insert
intosystem_books(bookid,bookname,bookstyleno,bookauthor,bookpub,bookpubdate,bookindate,isborrowed)
values('15154656','微观经济学','5','李小刚','北京大学出版社’,'2000-10-03','2001-11-15','1');
insert
intosystem_books(bookid,bookname,bookstyleno,bookauthor,bookpub,bookpubdate,bookindate,isborrowed)
values('5658','影视文学','4','苏庆东','北京大学出版社’,'1999-02-28','2000-01-21','1');
insertinto
system_books(bookid,bookname,bookstyleno,bookauthor,bookpub,bookpubdate,bookindate,isborrowed)
values('565800020','探索宇宙奥秘','2','苏庆东','北京大学出版社’,'1999-02-28','2000-01-21','1');
3.2.3将已有图书证的读者加入system_readers表中*/
insertintosystem_readers(readerid,readername,readersex,readertype,regdate)
values('X05620207','陈玉','女',学生','2014-9-2314:
23:
56')
insertintosystem_readers(readerid,readername,readersex,readertype,regdate)
values('X05620206','王韵芳',女',学生','2014-09-3013:
24:
54.623')
insertintosystem_readers(readerid,readername,readersex,readertype,regdate)
values('X05620204','钱婷婷',女',学生','2014-09-2711:
24:
54.123')
insertintosystem_readers(readerid,readername,readersex,readertype,regdate)
values('X05620202','潘垒','女',学生','2013-09-3013:
24:
54.473')
insertintosystem_readers(readerid,readername,readersex,readertype,regdate)
values('008415','于子甲','男','教师','2014-04-3009:
24:
54.478')
insertintosystem_readers(readerid,readername,readersex,readertype,regdate)
values('001456','卢彪','男','教师','2004-04-3009:
24:
54.478')
3.2.4添加已借书读者的记录,同时将在已借出的借阅标记置0*/
insertintoborrow_record(bookid,readerid,borrowdate)
values('00125415152','X05620202','2007-09-2711:
24:
54.123')
updatesystem_books
setisborrowed=0
wherebookid='00125415152'
insertintoborrow_record(bookid,readerid,borrowdate)
values('00125415153','X05620206','2007-12-2708:
26:
51.452')
updatesystem_books
setisborrowed=0
wherebookid='00125415153'andisborrowed='1'insertintoborrow_record(bookid,re