资源描述:
《数据库课程设计之图书管理系统》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库。
1、《数据库类课程设计》系统开发报告学号: 姓名:吴书敏题目: 图书借阅管理 指导教师: 高洁 提交时间: 2013年6月1日 计算机科学与应用系目录第一章需求分析1第二章系统功能设计22.1系统功能模块图第三章数据库设计33.1数据库设计33.2数据表设计53.3数据库编程7第四章功能模块的创建84.1创建向读者表插入数据的存储过程84.2创建向图书表中插入数据的存储过程94.3创建实现还书的存储过程104.4创建实现借书的存储过程114.5建立是否超期表值函数134.6查询模块14结束语18参考文献19第一章需求分析系统功能分析阶段的任务就是确定该系统要解决的
2、问题及其具体要求。需要通过与用户的交流和沟通明确对系统的功能要求,最终列出系统可以实现的功能由用户确认。1.总体方案(1)图书资料的管理图书管理员将采购的图书入库分类处理,同时建立相关的图书资料信息,如果该书已有,则修改现有书本等于原有书本数加上新增书本数。如果图书损坏也修改图书资料信息。如果图书出馆,则删除相关的图书资料信息。(2)读者资料管理系统管理员要为读者办理相应的图书证,读者填写登记表包括学号、姓名、性别基本信息。读者申请退证时,可以删除改读者的基本信息。(3)借书操作读者把借阅证和想借阅的图书交给图书管理员,管理员进行审核。如该读者是否有过期未还的图书,是
3、否借阅图书已经超过五本,有上述情况之一则借阅不成功。否则借阅成功。读者只可在该本书尚未超期的情况下才可以进行续借,否则借阅不成功。(4)还书操作读者把借阅证及要还的图书交给图书管理员,由他进行审核,如该图书有逾期则通知该读者交罚款。否则,图书交由图书管理员放回书库,并修改图书,读者借书信息表。25第二章系统功能设计通过通过对上述各项功能的分析、分类、综合,按照模块化程序设计的要求,得到如下图所示的功能模块图。借书处理还书处理超期处理图书资料维护读者资料维护图书资料查询读者资料查询借阅历史查询查询日常工作图书管理系统资料维护图2-1系统功能模块图25第三章数据库设计数据
4、库在一个管理信息系统中占有非常重要的地位,数据库结构的好坏将直接影响到应用系统操作效率已经能否保证数据的一致性、完成性和安全性。3.1数据库设计根据图书管理系统的功能要求,通过分析系统要设计的相关实体一集要收集、存储和操纵数据信息,得到如下图1234所示的系统E-R图。根据系统E-R图得到以下关系模式。·读者基本信息(读者号,姓名,性别,借书数量)·图书基本信息(图书号,书名,类型,作者,译者,出版社,内容,馆藏数,已借数)·还书基本信息(读者号,书号,还书数量,还书日期)·借书基本信息(读者号,书号,书名,借书数量,借书时间,应还时间)姓名读者性别读者号借书数量图1
5、3-1读者E-R图25书名图书类型编号作者被借数馆藏数价格译者内容出版社图23-1图书E-R图图书还书还书数量读者还书日期图33-1还书E-R图25图书借书书名读者借书数量应还日期借书日期图43-1借书E-R图3.2数据表设计根据关系模式,确定要建立的数据库和表。给表中添加说明,并建立主键和外键如下图5678所示:“读者”表图5“读者”表“图书”表:25图6“图书”表“还书”表图7“还书”表“借书”表:图8“借书”表然后给图书表中添加数据:/*向图书表中插入数据*/25USEbookmgGOINSERT图书VALUES('','子不语壹','漫画','夏达','NUL
6、L','新世纪出版社','NULL','18.00','6',’0’)GOINSERT图书VALUES('','子不语贰','漫画','夏达','NULL','新世纪出版社','NULL','18.00','6',’0’)GOINSERT图书VALUES('','子不语叁','漫画','夏达','NULL','新世纪出版社','NULL','18.00','6',’0’)GOINSERT图书VALUES('','子不语肆','漫画','夏达','NULL','新世纪出版社','NULL','18.00','6',’0’)GOINSERT图书VALUES('','子不语
7、伍','漫画','夏达','NULL','新世纪出版社','NULL','18.00','6',’0’)GOINSERT图书VALUES('','子不语陆','漫画','夏达','NULL','新世纪出版社','NULL','18.00','6',’0’)3.3数据库编程以下是各个表的创建代码:/************创建各个表*************************/CREATETABLE读者(readeridvarchar(9)NOTNULLPRIMARYKEY,readernamevarchar(20)NOTNULL,readers