《数据库SQL实训设计报告图书管理系统.doc》由会员分享,可在线阅读,更多相关《数据库SQL实训设计报告图书管理系统.doc(9页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、软件学院计算机系课程设计报告书课程名称:SQL SERVER数据库及应用课程设计题目:图书管理系统后台数据库设计课程设计日期:2009年11月学生姓名:学号:班级:指导老师:引言现今随着IT行业地飞速发展,我们的生活渐渐变得越来越轻便。为了方便图书管理工作流程,可以更清楚、方便地完成管理图书的,并能很好地管理图书资料。将把每个同学的信息输入系统里,系统就会自动保存,不需要用笔记进行分析,然后进行总结,只需要作一些小的操作便可以让系统自行帮我们进行统计分析并总结,大大节省了工作人员的工作量。为了本软件能顺利地开发出来,在这里主要使用SQL Server数据库作为后台数据库、ADO数据访问技术开发
2、一个客户机/服务器应用系统。通过该应用系统实现对图书管理员信息,学生信息,图书信息和图书借阅信息等的添加、修改和删除,并保证使数据达到3NF,有效减少数据的冗余和插入删除异常。通过对整个系统的开发,提高VB、T-SQL编程语言各个知识点的综合应用能力、Visual Basic + SQL Server语言编程和调试能力,为学习软件专业课程创建较扎实的理论基础和实践基础。一、 需求分析图书管理系统是为了适应新形式下学校图书管理工作而开发的一套管理系统。要求能够实现学校图书管理系统的自动导入,按照系统分析自动进行读书,根据比例要求自动生成图书传阅信息、能够查询、修改各种信息,对借阅、赔偿进行统计,
3、生成报表,基本满足学生工作人员的需要。二、 软件开发工具与环境概述 开发工具:前端环境:Microsoft Visual Basic 6.0后台数据库:Microsoft SQL Server 2000 运行环境:硬件环境: CPU:800MHz以上内存:128M或更高硬盘:20G操作系统: Windows 98/2000/XP/2003三、 系统设计 系统功能设计1系统总体数据流程图读者借阅信息调动系统借阅图书登录 借阅分析2.系统的主要功能(1)图书管理模块:用来实现图书的登记、借阅、赔偿。(2)图书资料模块:用来实现图书的查询输出。(3)图书管理员模块:用来实现管理人员的值班浏览。(4)
4、投诉管理模块:用来实现对管理人员的投诉管理。 数据库设计1系统的概念结构设计系别学号图书编号图 书借书证号姓名学 生图书借阅信息学生学号图书编号工作人员编号密码学生学号图书编号用户名用户身份用户图书借阅信息登录学 生姓名借书证号系 别学 号图书赔偿图书编号借书证号工作人员编号图 书是否借出管理员值班时间图书编号2系统的逻辑结构设计用户信息表(用户名,密码,用户身份) 图书管理员信息表(工作人员编号,姓名,性别,值班时间) 学生信息表(学生学号,班级编号,学生姓名,性别,系别) 图书信息表(图书编号,类别编号,类别名称,图书名称,作者姓名,出版社名称,图书简介,定价,能否借出,封面) 图书借阅信
5、息表(图书名称,借书证号,学号,工作人员编号,借出数量,剩余数量) 图书赔偿信息表(借书证号,图书编号,工作人员编号,借书日期,应还日期,赔偿原因,赔偿金额,解决方案) 投诉管理信息表(借书证号,工作人员编号,投诉日期,投诉内容)3系统的物理结构设计系统关系图用户信息表结构列名数据类型可否为空用户名varchar(50)NOT NULL密码varchar(50)NOT NULL用户身份char(10)NULL学生信息表列名数据类型可否为空学生学号char(12)NOT NULL班级编号char(10)NOT NULL借书证号char(10)NOT NULL 学生姓名 char(20) NOT
6、NULL性 别 char(5) NOT NULL 系 别 char(20) NOT NULL图书管理员信息表列名数据类型可否为空工作人员编号char(12)NOT NULL姓 名char(20)NOT NULL性 别char(5)NOT NULL 值班时间 datetimeNOT NULL图书借阅信息表列名数据类型可否为空图书名称char(20)NOT NULL学生学号char(12)NOT NULL借书证号char(10)NOT NULL工作人员编号 char(12) NOT NULL借出数量char(10)NOT NULL剩余数量char(10)NOT NULL图书信息表列名数据类型可否为
7、空图书编号char(20)NOT NULL类别编号char(20)NOT NULL类别名称 varchar(20)NOT NULL图书名称 varchar(20) NOT NULL作者姓名 char(20) NULL出版社名称 varchar(50) NULL图书简介 text NULL能否借出 char(5) NOT NULL封面imageNULL图书赔偿信息表列名数据类型可否为空借书证号char(10)NOT NULL图书编号char(20)NOT NULL工作人员编号char(12)NOT NULL借书日期datetimeNOT NULL应还日期datetimeNOT NULL赔偿原因t
8、extNOT NULL赔偿金额moneyNOT NULL解决方案textNULL投诉管理信息表列名数据类型可否为空借书证号char(10)NOT NULL投诉日期datetimeNOT NULL投诉内容 textNOT NULL工作人员编号 char(12) NOT NULL 学生信息表数据如下: 图书管理员信息表数据如下: 图书借阅信息表数据如下:4系统的实现 界面设计 系统的登录界面 系统功能(主菜单)A系统管理(修改用户;用户管理;重新登录;退出系统)B图书管理员信息管理(添加工作人员信息;修改工作人员信息;删除工作人员信息)C学生信息管理(添加学生信息;修改学生信息;删除学生信息)D图
9、书信息管理(添加图书信息;修改图书信息;删除图书信息)E. 图书借阅信息管理(添加图书借阅信息;修改图书借阅信息;删除图书借阅信息)F. 图书赔偿信息管理(添加图书赔偿信息;修改图书赔偿信息;删除图书赔偿信息)G. 投诉管理信息管理(添加投诉管理信息;修改投诉管理信息;删除投诉管理信息)H查询信息(图书管理员信息;查看学生信息;查看图书信息等)I帮助(About) SQL语句实现 功能代码:(学生信息表)全部信息select *from 学生信息表go 查询学生信息表中的学生姓名为“李白”的全部信息 select * from 学生信息表where 学生姓名=张柏芝go 在图书信息表中图书名称
10、为SQL的图书信息select * from 图书信息表where 图书名称=SQLGO查询学生学号为“”所借图书的日期select 学生信息表.学生学号,学生姓名,图书赔偿信息表.借书证号,借书日期from 学生信息表,图书赔偿信息表where 图书赔偿信息表.借书证号=学生信息表.借书证号and 学生信息表.学生学号=查 查询学生姓名为谢娜的学生借阅的书是否过期并算出超期天数select 学生信息表.学生学号,学生姓名,图书赔偿信息表.借书证号,(datediff(day,借书日期,还书日期)-30)as 超期天数from 学生信息表,图书赔偿信息表where 图书赔偿信息表.借书证号=学
11、生信息表.借书证号and 学生信息表.学生姓名=谢娜统计各系别超过2人的信息select 系别, count (系别) as 人数from 学生信息表group by 系别having count(系别)2信息修改:增添Insert 学生信息表(学生学号,班级编号,借书证号,学生姓名,性别,系别)values (, 3483,RH0003,小雪, 女,软件)go修改update 学生信息表set学生学号=where学生学号=go 删除 Delete 学生信息表Where 学生学号 =Go四、 结束语实训对于我们来说是一个很好的锻炼机会,因为它不仅让我们体会到了作一个完整的数据库过程,还是对我们对这门学科综合能力的检测。在制作过程中很辛苦,但是在最后作品出来以后我们体会到了成功的快乐。在制作过程中遇到困难是难免的,而解决问题的关键是自己应该对所学知识熟练的掌握。所以我们会更加努力学习,争取以后能做出更好的作品。附:参考文献1 李鸿吉,Visual Basic6.0中文版编程方法详解. 科学出版社2 王寅永,李降宇,李广歌. SQLServer深入详解.电子工业出版社3 周仁云. SQL Server2005案例教程.对外经济贸易大学出版社4 许冰Visual basic编程资源大全2004中国青年出版社5
限制150内