图书借阅管理系统_第1页
图书借阅管理系统_第2页
图书借阅管理系统_第3页
图书借阅管理系统_第4页
图书借阅管理系统_第5页
已阅读5页,还剩17页未读 继续免费阅读

下载本文档

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

文档简介

1、指导老师:刘登刚学校图书借阅管理系统姓名:王崟丞学号:201502334079班级:2015级信息与计算科学、题目及要求说明。题目:学校图书借阅管理系统I、报告题目要求任选一个项目,调查分析一个具体的或模拟的实例描述该实例的业务信息和管理工作的要求;列出实体、联系;指出实体和联系的属性;(5)画出E-R图;(6)将E-R图转换成关系模式,并注明主键和外键;(7)建立数据字典;(8)创建数据库;(9)根据题目的要求写查询、存储过程、触发器等。II、项目举例功能要求:实现图书信息、类别、出版社等信息的管理;实现读者信息、借阅证信息的管理;实现图书的借阅、续借、归还管理;实现超期罚款管理、收款管理;

2、创建触发器,分别实现借书和还书时自动更新图书信息的在册数量创建视图查询各种图书的书号、书名、总数和在册数;创建存储过程查询指定读者借阅图书的情况;建立数据库相关表之间的参照完整性约束。二、说明书。(I)问题的描述图书馆管理系统开发。系统开发的总的设计目标是实现图书管理的系统化、规范化和自动化,实现对图书资料的集中统一的管理。本系统主要实现对图书借阅信息的管理,主要功能为管理有关读者、图书、借阅、征订和管理员的信息等。图书借阅管理系统是一种基于集中统一规划的数据库数据管理新模式。本系统主要实现对图书借阅信息的管理,主要功能为管理有关读者、图书、借阅和管理员的信息等。图书借阅管理系统是一种基于集中

3、统一规划的数据库数据管理新模式。本系统结构分为基础信息维护,读者管理,图书管理,图书流通管理。读者管理可以浏览读者的信息,可以对读者信息进行维护。图书管理可以浏览图书的信息,可以对图书信息进行维护。借阅管理可以显示当前数据库中书籍借阅情况,可以对借阅信息进行维护。读者管理可以浏览读者的信息,可以对读者信息进行维护。图书管理可以浏览图书的信息,可以对图书信息进行维护。借阅管理可以显示当前数据库中书籍借阅情况,可以对借阅信息进行维护。(II)需求分析(ni)需求分析(ii.i.1)基础信息维护在图书借阅管理系统中,基础信息包括:读者信息和图书信息。这些信息可以在读者档案管理,图书档案管理中应用。在

4、读者档案管理中,读者的类别信息实现读者权限划分;在图书档案管理中,图书类型信息实现图书类别的划分。读者管理管理员对读者管理可以实现浏览,添加,修改操作,在添加读者信息时需一个读者证号对读者身份进行辨别,此编号必须唯一,还需要登记读者的详细信息。图书管理管理员对图书管理可实现添加,修改和删除操作,在添加图书信息时需给图书建立一个图书编号,编号唯一。还需要等级图书的详细信息,在实现图书修改时,图书编号不可修改。实现图书信息的删除时要验证图书是否归还,如没有归还,将不能实现图书的删改。图书流通管理图书流通管理需要实现图书的借阅,归还功能。图书的借阅时要登记读者证号和图书编号,以及管借阅和归还的时间。

5、图书归还要检查是否逾期,若逾期将交罚款,否则正常返还。(II.2)系统功能结构借阅图书:读者通过浏览图书信息确定要借阅的书籍,由管理员处理借阅信息,并进行借阅登记。归还图书:读者将已借阅的图书归还给图书馆,管理员检查图书并做相应的登记。读者注册:读者通过注册页面,填写个人信息,系统显示信息通过后,管理员给予读者借书卡一张。(6)续借管理:读者想继续阅读已到归还日期的图书,可通过网上续借或当面续借。(7)罚款处理:读者未按时归还图书也未办理续借或照成图书损坏,则按照书馆规定由管理员处罚相应金额的罚款。(II3)数据流图顶层数据流图中层数据流图Pl注fflW4通屯登记_*_-_P4圈书W懂亠辽书i

6、fi知十田书疋週-伯书登记-冏书归证底层数据流图(A)注册管理数据流程底图。PLi注册审核B)还书管理数据流程底图。P2还书处理管哩员D2借J还信息P2.2超期还书罚謊规则D3嚣款文件+借书卡囹书港息+超期处理C)借书管理数据流程底图。DI读者信息借书卡+舍格读音D2图书信忌们简还倩书信息P3.2诸书登记管理園D)图书管理数据流程底图。P4.1图书査10+査询,P4.2圏书蜩亠删际囲书:修改图书D3囹书信息D2ffi.f息+章询圖*劭冏书苣13员P4.J图菇修改(III)逻辑结构设计(III.1)局部E-R图。II(11)注册管理E-R图俏书卡号注册时弓辰系方式(12)还书管理E-R图II佶书

7、时冃拽书时可I【佶书卡号!娃宕狂咬文件卷吕P叢主司F轅門帀;书卡可国书忙冬书宅j(S4WIB号出匡担)盘査)fegttj单尬I/X(HL1.3)借书管理E-R图at吉惜為国问址;SIL換抑i丹卜书鬥蛀屯密码注1B吋间图书佶歸ES书堀号库存更密锂员话迈归甩II.1.4)图书管理E-R图械理员统号密闵借书卡E査科定册时目醉辛Ji艺蚩徊娃宕罔扣貝号书名tsZ訪繭亦件需迈;士回営理员出盛社$书时同号库再呈(III.2)全局E-R图。47专-+Ttvtiar!圈L-tatE童耶FPp-pliJflSS田u:曲(III.31)数据流条目注册申请数据流条目数据流名称注册申请简述读者第一次想图书馆借阅书籍时需

8、要注册登记别名无组成注册申请=申请卡号+姓名+密码+注册时间+联系方式图书借阅数据流条目数据流名称图书借阅简述读者向图书馆进行图书借阅是需要进行相应的登记别名无组成图书借阅=借书卡号+密码+书名+借阅数量+借阅日期(HI.3.2)存储条目读书信息文件条目文件名、七-4y/亠白读者彳信息、简述包括所有读者的信息别名无组成读者信息=借书卡号+姓名+密码+注册时间+联系方式借/还信息文件条目文件名借/还信息简述包括所有读者借书以及归还图书的所有记录别名无组成借/还信息=借书卡号+姓名+密码+借书时间+还书时间+联系方式图书信息文件条目文件名图书信息简述包括所有图书的信息)别名无组成图书信息=图书编号

9、+图书名称+图书位置+库存量+单价罚款信息文件条目文件名罚款文件简述包含所有罚款信息别名无组成罚款信息=借书卡号+密码+姓名+罚款原因+罚款金额(III.3.3)数据项条目借书卡号数据项条目文件名借书卡号简述每个读者注册时的卡号别名无组成借书卡号-年份(XXXX)+月份(XX)+序号(XX)值类型9位数字取值范围图书编号数据项条目文件名图书编号简述包括图书的具体位置别名无组成图书编号=图示类别(XXXXX)+书架号(XXXX)+序列号(XX)+图书名称(XXXXX)值类型17位数字取值范围(IV)数据库实现(IV.1)数据库及数据库对象创建的SQL语句。tb_reader学生表CREATETA

10、BLEtb_reader(readeridvarchar(lO)NOTNULL,rnamevarchar(20)NOTNULL,sexvarchar(2)NOTNULL,gradevarchar(l)NOTNULL,Professionvarchar(20)NOTNULL,ifeffectivetinyint(4)NOTNULL,emailvarchar(20)DEFAULTNULL,PRIMARYKEY(readerid)tb_manager管理员表CREATETABLEtb_manager(manageridvarchar(lO)NOTNULL,loginnamevarchar(20)NO

11、TNULL,passwordvarchar(20)NOTNULL,PRIMARYKEY(managerid)tb_borrow借阅表CREATETABLEtb_borrow(borrowidint(ll)NOTNULLAUTO_INCREMENT,bookidvarchar(l0)NOTNULL,readeridvarchar(l0)NOTNULL,manageridvarchar(l0)NOTNULL,borrowTimedatetimeNOTNULL,backTimedatetimeNOTNULL,ifreborrowtinyint(4)NOTNULL,PRIMARYKEY(borrowi

12、d)tb_book图书表CREATETABLEtb_book(bookidvarchar(l0)NOTNULL,bnamevarchar(20)DEFAULTNULL,typevarchar(20)DEFAULTNULL,authorvarchar(20)DEFAULTNULL,pricefloat(l0,2)DEFAULTNULL,publishvarchar(20)DEFAULTNULL,quantitytinyint(4)NOTNULL,remaintinyint(4)NOTNULL,PRIMARYKEY(bookid)tb_punishment超期处罚表CREATETABLEtb_bo

13、ok(bookidvarchar(l0)NOTNULL,bnamevarchar(20)DEFAULTNULL,typevarchar(20)DEFAULTNULL,authorvarchar(20)DEFAULTNULL,pricefloat(l0,2)DEFAULTNULL,publishvarchar(20)DEFAULTNULL,quantitytinyint(4)NOTNULL,remaintinyint(4)NOTNULL,PRIMARYKEY(bookid)tb_purview管理员权限设置表CREATETABLEtb_book(bookidvarchar(10)NOTNULL,

14、bnamevarchar(20)DEFAULTNULL,typevarchar(20)DEFAULTNULL,authorvarchar(20)DEFAULTNULL,pricefloat(10,2)DEFAULTNULL,publishvarchar(20)DEFAULTNULL,quantitytinyint(4)NOTNULL,remaintinyint(4)NOTNULL,PRIMARYKEY(bookid)(IV.2)存储过程创建存储过程,输入读者id查询出书名、借阅时间、归还时间、管理员id、是否续借情况createprocedurepreaderid_invarchar(10),

15、bookid_invarchar(20),bname_outvarchar(20)output,borrowTine_outdatetimeoutput,backTime_outdatetimeoutput,managerid_outvarchar(20)output,ifxeborom_outtinyintoutputasselectbname_out=bname,borrowTime_out=borrowTimebackTime_out=backTime,managerid_out=managerid,ifreborrow_out=ifreborrowfromtb_book,tb_borr

16、owwheretb_borrow.readerid=readerid_inandtb_borrow.bookid=bookid_inandtb_book.bookid=b_borrow.bookid存储过程使用declarereaderid_invarchar(10),bookid_invarchar(20),bname_outvarchar(20),borrowTime_outdatetime,backTime_outdatetime,managerid_outvarchar(10),ifreborrow_outtinyintselectreaderid_in=2010508033selee

17、tbookid_in=005execpreaderid_in,bookid_in,bname_outoutput,borrowTime_outoutput,backTime_outoutput,managerid_outoutput,ifreborrow_outoutputprint书名:+bname.outprint借书吋囘:+rtrim(borrowTime_outprint还书肘囘:+tim(backTime_outprint管理员编号:+managerid_outprint是否续借:+rtrim(ifreborrow_out)(IV.3)触发器(IV.3.1)借书触发器。当借书时,图书

18、表中的remain(剩余图书)自动减一。createtriggert_borrowontb_borrowforinsertasdeclarebookid_readvarchar(10)selectbookidread=bookidfrominsertedbeginupdatetb_booksetremain=remain-1wherebookid=bookid_readEnd(IV.3.2)还书触发器。当还书时,图书表中的remain自动加一。createtriggert_backontb_borrowforupdateasifupdate(backTime)declarebookid_rea

19、dvarchar(10selectbookid_read=bookidfrominsertedbeginupdatetb_booksetremain=remin+1wherebookid=bookid_readEnd(IV.3.3)罚款触发器,当借阅图书短期时,自动在punishment表中添加罚款记录。记录罚款读者、书名、天数、金额并且自动将reader表中的ifeffective置为0,使该读者不能再借书。createtriggert_punishontb_borrowforupdateasifupdate(backTime)begindeclarebackTimedatetine,bor

20、rowTimedatetime,ifxeborrowtinyint,daysint,days1int,bmoneyint,readeridvarchar(10),bookidvarchar(10)selectbackTime=backTimefrominsertedselectborrowTime=borrowTimefrominsertedselectifreborrow=ifreborrowfrominsentedselectday=convert(int,backTime)-convert(int,boxrowTime)selectreaderid=readeridfrominserte

21、dselectbookid=bookidfrominsertedifdays30beginififreborrow=1beginifdays60beginselectdays1=days-60selectmoney=days1*0.1insertintotb_punishment(readerid,bookid,days,bmoney)values(readerid,bookid,days1,bmoney)updtetb_readersetifeffective=0whexereaderid=readeridendendififreborrow=0beginselectdays1=day-30

22、selectmoney=days1*0.1insertintotb_punishment(radeeid,bookid,days,bmoney)values(readerid,bookid,days1,bmoney)updatetb_readersetifeffective=0wherereaderid=readeridendendend(IV.3.4)读者是否有效触发器。当读者借书时,检查reader表中的ifeffective属性,若为0则说明有短期罚款,不能借书。creztetriggert_ifcanborrowontb_borrowforinsertdeclarereaderidva

23、rchar(10),ifeffectivetinyintselectreaderid=readeridfrominsertedselectifeffective=ifeffectivefromtb_readerwherereaderid=readeridififeffective=0begin1print您有短期罚款rollbacktransactiomend(IV.4)视图创建视图查询各种图书的书号、书名、总数和在册数。createviewview_queryasselectbookid,bname,quantity,remainfromtb_book创建视图查询读者的短期罚款情况。其中包括

24、读者号。读者姓名。罚款书名,罚款金额。createviewview_readerasselecttb_punishment.readerid;,rname,bname,bmoneyfromtb_pumishment,tbbook,tb_readerwheretb_pumishment.bookid=tb_book.bookidandtb_punishment.readerid=tb_reader.readerid(V)结论一、数据库主要知识点我们首先从第一章绪论了解了数据库的概念,其中有几个较为重要的知识点,即数据库(DB)、数据库系统(DBS)、数据库管理系统(DBMS)的概念以及数据库管理

25、员(DBA)的职责。此外本章还介绍了数据库发展的三个阶段:人工管理阶段、文件系统阶段和数据库系统阶段。第二章介绍了数据模型和三层模式数据库。本章要求我们理解实体-联系方法,并学会绘制E-R图。此外还应掌握概念数据模型的意义和传统的三大数据模型,以及数据独立性和数据库三层模式结构。接着开始着重讲述现在普遍使用的关系数据库。包括关系数据模型的数据结构和基本术语,关系模型的完整性约束和关系代数运算。重点是关系模式完整性的分类和功能,以及关系代数中集合运算和关系运算。最后介绍了关系数据库系统的三层模式结构。第五章系统讲述了关系数据库的标准语言SQL的定义功能、查询功能、操作和控制功能。重点在于数据查询

26、功能。另外还介绍了视图的用法和动态SQL中定义、操作和查询功能。第六章的知识点有:存储过程的创建和执行过程、修改和删除;触发器的基本概念,建立,插入和删除视图,插入、删除和更新类触发器。最后介绍了数据完整性。第七章介绍安全性,包括安全性措施的层次、数据库管理系统的安全功能等,用户管理和角色管理,权限管理。其他的安全问题包括:数据加密、审计、统计数据库和用户定义的安全性措施。事务管理这一章首先介绍了事务的概念、性质以及SQL对事务的支持。并发控制干扰问题、可串行性、封锁、死锁、隔离级别、封锁与隔离级别;恢复故障类型、备份类型、日志的概念、恢复模型、备份转储、还原。第九章为关系数据理论:函数依赖术

27、语和符号;函数依赖的公理系统Amstrong公理的内容及其正确性、逻辑蕴含和闭包、公理的完备性、闭包的计算、函数依赖集的等价和最小化;规范化一一1NF、2NF、3NF、BCNF;模式分解。第十章:数据库设计。完善E-R模型中的概念一一弱实体,依赖关系,强制联系;数据库设计的过程主要掌握其建立的步骤。第十一章介绍面向对象数据库:新的数据库应用和新的数据库类型;面向对象的数据模型一对象与类;对象的属性、方法和状态、对象的交互和消息、类的确定和分化、封装、继承、多态;对象关系数据库与对象数据库;面向对象数据库的研究。十二章“数据库应用的结构和开发环境”并非重点,而第十三章的内容在软件工程课程中就已经

28、掌握,所以这两章的知识点就略过了。第十四章分布式数据库与分布式数据管理:概念;分布式数据库的分布方式;分布式数据库特点和目标更新传播、分布式查询处理、目录表管理、分布式事务管理;SQLServer的复制及其术语、复制模型。十五章数据仓库:概念;结构;数据仓库系统;建立数据仓库系统;实现数据仓库的数据库模型;数据仓库与决策支持。最后,数据库研究和应用的新领域这一章中掌握知识库的知识即可。二、学习数据库的心得SQL(结构化查询语言)是用于执行查询的语法。但是SQL语言也包含用于更新、插入和删除记录的语法。查询和更新指令构成了SQL的DML部分:SELECT-从数据库表中获取数据UPDATE-更新数

29、据库表中的数据DELETE-从数据库表中删除数据INSERTINTO-向数据库表中插入数据SQL的数据定义语言(DDL)部分使我们有能力创建或删除表格。我们也可以定义索引(键)规定表之间的链接,以及施加表间的约束。SQL中最重要的DDL语句:CREATEDATABASE-创建新数据库ALTERDATABASE-修改数据库CREATETABLE-创建新表ALTERTABLE-变更(改变)数据库表DROPTABLE-删除表CREATEINDEX-创建索引(搜索键)DROPINDEX-删除索引数据库有保持数据的独立性,所谓数据独立,是指存储在数据库中的数据独立于处理数据的所有应用程序而存在。也就是说,数据是客观实体的符号化标识,它就是一个客观存在,不会因为某一项应

温馨提示

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

评论

0/150

提交评论