数据库图书管理系统含代码文档格式.docx
《数据库图书管理系统含代码文档格式.docx》由会员分享,可在线阅读,更多相关《数据库图书管理系统含代码文档格式.docx(15页珍藏版)》请在冰豆网上搜索。
读者注册。
读者注册时要求填写基本信息,包括读者编号、姓名、性别、联系电话、学院等。
系统检查所有信息填写正确后读者注册成功。
(2)图书管理
增加图书信息。
当有新的图书入库时,管理员负责添加图书信息,包括书名、分类、图书编号、作者、出版社、出版时间、简介等。
图书信息查询。
管理系统需提供方便快捷的方式进行图书检索。
如可以输入指定的关键词进行简单查询,也可以根据书名、分类、图书编号、作者、出版社、出版时间、简介等单一或组合条件进行查询。
图书信息更新及删除。
图书信息发布后,管理员可以随时更新和删除图书信息。
(3)借阅图书
读者登入图书管理系统之后,将需要的图书的信息输入,可以借阅图书。
由管理员将图书信息修改为“不在馆”。
(4)续借图书
读者借书之后,一个月后应归还。
如有需要可以续借图书30天。
此操作由管理员完成。
(5)归还图书
读者将已借图书归还给图书馆时,需要管理员确认信息。
并将图书信息修改为“在馆”
3.业务规则分析
基于功能需求,通过进一步了解,图书管理业务需求如下:
(1)所有用户均可以搜索图书信息。
但只有管理员可以对图书信息进行修改。
(2)管理员由管理员编号唯一标识。
(3)每位读者由读者编号唯一标识。
(4)图书编号是图书的唯一标识。
(5)借阅图书后需记录图书当前状态包括在馆、不在馆、已归还、未归还、是否续借。
(6)同一图书分类中可以有多本图书,但是每本图书只能在一种个图书分类中。
三.实体集及属性
图3-1图书实体集E-R图
图3-2管理员实体集E-R图
图3-3读者实体集E-R图
图3-4图书分类实体集E-R图
四.联系集及E-R图
五.逻辑数据库设计
表3-1BookClass
属性名称
数据类型
属性描述
classNo
varchar(3)
分类编号
ClassName
varchar(20)
分类名称
表3-2Book
bookNo
图书编号
bookName
图书名称
author
varchar(12)
作者
publishName
varchar(50)
出版社
publishDate
datetime
出版时间
introduction
varchar(200)
简介
表3-3Reader
readerNo
读者编号
readerName
varchar(10)
读者姓名
rSex
varchar
(2)
读者性别
rPhoneNumber
联系电话
institute
学院
effectDate
生效日期
lostEffectDate
失效日期
breakRules
char
(2)
违规情况
borrowAdd
int
累计借书
表3-4Admin
adminNo
管理员编号
adminName
管理员姓名
aSex
管理员性别
aPhoneNumber
address
varchar(40)
家庭住址
表3-5Borrow
borrowDate
结束日期
shouldDate
应该归还日期
renewal
char(4)
是否续借
表3-6Admin_Book
shopTome
入库时间
inLibrary
是否在馆
表3-7Admin_Reader
brCheck
归还确认
六.数据库编程
1.创建表
(1)创建图书分类表BookClass
CREATETABLEBookClass(
classNovarchar(3)notnull,
classNamevarchar(20)null,
CONSTRAINTBookClassPKPRIMARYKEY(classNo)
)
(2)创建图书表Book
CREATETABLEBook(
bookNovarchar(20)notnull,
classNovarchar(3)notnull,
bookNamevarchar(50)notnull,
authorvarchar(12)notnull,
publishNamevarchar(50),
publishDatedatetime,
introductionvarchar(200),
CONSTRAINTBookPKPRIMARYKEY(bookNo),
CONSTRAINTBookPK1FOREIGNKEY(classNo)REFERENCESBookClass(classNo)
)
(3)创建管理员表Admin
CREATETABLEAdmin(
adminNovarchar(12)notnull,
adminNamevarchar(12)notnull,
aSexvarchar
(2)notnull,
aPhoneNumbervarchar(12)null,
addressvarchar(40)null,
CONSTRAINTAdminPKPRIMARYKEY(adminNo)
(4)创建读者表Reader
CREATETABLEReader(
readerNovarchar(12)notnull,
readerNamevarchar(10)notnull,
rSexvarchar
(2)notnull,
rPhoneNumbervarchar(12)null,
institutevarchar(20)notnull,
effectDatedatetime,
lostEffectDatedatetime,
breakRuleschar
(2),
borrowAddint,
CONSTRAINTReaderPKPRIMARYKEY(readerNo)
(5)创建借阅表Borrow
CREATETABLEBorrow(
bookNovarchar(20)notnull,
readerNovarchar(12)notnull,
borrowDatedatetimenotnull,
shouldDatedatetimenotnull,
renewalchar(4)notnull,
CONSTRAINTBorrowPKPRIMARYKEY(adminNo,readerNo,bookNo),
CONSTRAINTBorrowPK1FOREIGNKEY(adminNo)REFERENCESAdmin(adminNo),
CONSTRAINTBorrowPK2FOREIGNKEY(readerNo)REFERENCESReader(readerNo),
CONSTRAINTBorrowPK3FOREIGNKEY(bookNo)REFERENCESBook(bookNo),
)
(6)创建管理员_图书表Admin_Book
CREATETABLEAdmin_Book(
shopTimedatetime,
inLibrarychar(4)
CONSTRAINTAdmin_BookPKPRIMARYKEY(adminNo,bookNo),
CONSTRAINTAdmin_BookPK1FOREIGNKEY(adminNo)REFERENCESAdmin(adminNo),
(7)创建管理员_读者Admin_Reader
CREATETABLEAdmin_Reader(
bookNovarchar(20)notnull,
brCheckchar(4)notnull,
CONSTRAINTAdmin_readerPKPRIMARYKEY(adminNo,readerNo,bookNo),
CONSTRAINTAdmin_readerPK1FOREIGNKEY(adminNo)REFERENCESAdmin(adminNo),
CONSTRAINTAdmin_readerPK2