资源描述
《数据库技术》课程实训指导书
一、 实训课程性质和任务
《数据库技术》课程实训是在完成了理论教学和课内实训之后安排的综合实训。其目的和任务是让学生更加熟练地掌握数据库对象的基本操作、 数据查询等内容, 对数据库及数据库设计、 SQL语言的运用, 以及管理信息系统的分析、 设计方法有初步了解, 对管理信息系统项目的组织策划、 资源管理、 团队精神也有一定的认识。
《数据库技术》课程实训任务主要按照面向对象程序设计和数据库应用技术两门课程的教学内容来进行, 它是以一个实际管理信息系统(MIS)的开发过程为背景来实施, 实训经过一个完整的MIS项目开发, 提高学生的应用开发能力及实际编程能力, 使学生掌握数据库系统的基本概念、 原理和应用, 了解数据库系统在实际应用中的开发方法及研制过程, 为今后从事管理信息系统的研究、 开发、 应用提供必要的知识, 更好地完成各种计算机应用和开发任务。
本课程的实训分为前期准备阶段、 基本操作阶段和技术提高阶段三个阶段进行: 前期准备阶段的实验围绕数据库系统设计进行, 它要求学生根据教科书的内容, 设计一个自选的实际数据库系统, 并完成相应的设计报告; 基本操作阶段的实验围绕着数据库系统的基本操作进行, 其内容主要是有关数据库定义、 数据操纵和数据控制功能, 它要求学生结合书本上有关数据库系统和数据库语言的知识完成; 技术提高阶段的实验不但要求把书本上的内容掌握好, 同时还需要自学一些相关的知识。
实训的软件环境为Microsoft SQL Server 。
二、 实训基本要求
实训采用分组方式进行, 每组选定一个管理信息系统的题目, 组内能够进行讨论, 互相学习提高。每个组员具体做一个模块, 组长负责总体协调和系统联调。在实训的过程中, 要求组长带领组员深入现有系统进行深入调查, 弄清用户需求。同时, 要求组长督促组员都要参与开发的全过程, 并鼓励组员选择MIS系统中除基本功能外的其它功能或者使用特别方法实现功能的, 作为创新设计的尝试。
具体要求如下:
1.要充分认识课程设计对培养自己的重要性, 认真做好设计前的各项准备工作。
2.既要虚心接受老师的指导, 又要充分发挥主观能动性。结合课题, 独立思考, 努力钻研, 勤于实践, 勇于创新。
3.独立按时完成规定的工作任务, 不得弄虚作假, 不准抄袭她人内容, 否则成绩以不及格计。
4.都要严格遵守学校的学习纪律、 规章制度, 学生有事离校必须请假。课程设计期间, 无故缺席按旷课处理; 缺席时间达四分之一以上者, 其成绩按不及格处理。
5.在设计过程中, 要严格要求自己, 树立严肃、 严密、 严谨的科学态度, 必须按时、 按质、 按量完成课程设计。
6.小组成员之间, 分工明确, 但要保持联系畅通, 密切合作, 培养良好的互相帮助和团队协作精神。
三、 实训教学条件
⑴ 先行已开设可视化程序设计课程, 并学完《数据库技术》的基本内容。
⑵ 具备客户机/服务器模式的网络实验室作为学生实训操作的场地。
四、 实训内容
⑴ 需求分析
要求学生掌握数据库设计的基本技术, 熟悉数据库设计的每个步骤中的任务和实施方法。并加深对数据库系统概念和特点的理解。
利用数据库设计的4个阶段: 需求分析( 分析用户要求) 、 概念设计( 信息分析和定义) 、 逻辑设计( 设计实现) 和物理设计( 物理数据库设计) 进行。概念模型设计时采用自底向上的方法, 即自顶向下地进行需求分析, 然后再自底向上地设计概念结构, 和自底向上的设计方法。
① 用户的功能需求分析, 要深入到用户和现有的实际系统中, 弄清楚现有系统业务流和数据流运动过程。
② 画出系统的功能图。
需求分析时, 找出系统中的实体及实体间的关系, 定义实体的必要属性、 类型, 域, 分析实体间的关系, 码及外码等。
( 2) 概念结构设计
绘制所选实习项目详细的E-R图。
( 3) 逻辑结构设计
将E-R图转换成等价的关系模式; 按需求对关系模式进行规范化; 对规范化后的模式进行评价, 调整模式, 使其满足性能、 存储等方面要求; 同时实现关系及关系间的数据的有效性及完整性约束。根据局部应用需要设计外模式。
( 4) 物理结构设计
选定实施环境, 存取方法等。
要求学生熟练掌握和使用Transact-SQL、 SQL Server 企业管理器创立数据库、 表和修改表结构, 并学会使用SQL Server 查询分析器接收Transact-SQL语句和进行结果分析。
① 数据库的建立:
② 建立各种数据库表, 表的主键、 外键及关联等。
( 5) 数据实施和维护
用SQL Server 环境实施数据的加载, 实现各种查询。
( 6) 设计小结: 总结课程设计的过程、 体会及建议。
五、 实施办法
1. 选题: 根据现实经济生活和学生生活, 参考后面附录中提供的题目, 要求难易适中, 业务情况容易了解, 涉及其它专业的”专业性”不要太强。
学生能够自己单独选题, 或者以3-4个同学为一组共同协作进行一题目的设计小组形式选题。但一定要按本课程设计要求进行, 各组题目不能重复。
2.分工要求
( 1) 负责工作流和功能分析, E-R图设计, 书写相应设计文档。 1人
( 2) 负责关系模式设计, 书写相应设计文档。 1人
( 3) 负责系统的设计。 1-2人
六、 实训学时分配
序号
内 容
时 间
合计
1
实训动员
0.5天
5天
2
需求分析
0.5天
3
上机设计
3天
4
系统验收
0.5天
5
实训材料撰写并上交
0.5天
七、 实训成果
将数据库应用技术和面向对象程序设计结合起来进行实训, 能够使同学们从系统的需求分析开始, 经历数据库的设计、 优化, 到功能规划、 窗体设计、 界面设计、 报表设计、 编码、 调试等整个开发过程, 使同学们对MIS整个开发过程有一个较全面的认识。提高同学们的知识综合应用能力, 体验学习成果, 激发同学们后续课程学习兴趣。成果形式包括实训报告书、 开发的管理信息系统源代码以及使用说明文档。
其中实训报告书应说明:
(1) 实训目的
(2) 实训任务
(3) 需求分析
(4) 概念模型设计
(5) 逻辑模型设计
(6) 数据库设计
(7) 数据查询的实现
(8) 遇到的关键问题及解决办法
(9) 实训启示与感想。
八、 实训考核
实训考核是检查学生的实训成果, 检测学生对《数据库技术》课程知识的理解程度, 以及应用数据库进行数据管理的能力。
为了确保检验的真实性, 实训结束前要进行答辩和演示, 并将实训报告书、 管理信息系统源代码和使用说明文档, 交到服务器上的共享文件夹中, 实训指导老师根据以上内容来评定成绩。
九、 说明
⑴ 实训是在课堂学习以及相关先行课程学习后的基础上安排的实训, 要求学生已具备一定的程序设计和业务流程的应用基础。
⑵ 实训内容要求以一个管理信息系统(例如, 学生成绩管理系统、 人事管理系统、 物流管理系统等)为题材进行实际开发才有意义, 才能锻炼学生在开发管理信息系统的过程中所需的综合能力和培养学生团队精神和团队协作的能力。
⑶ 实训完成后, 必须测试系统功能和书写实训报告, 并进行演示和答辩。
十、 附录
(1) 新生报到管理系统
根据新生报到的基本流程, 该系统主要应具有以下基本功能:
l 新生数据管理: 包括新生数据的录入、 修改、 删除等功能。
l 新生领取报到单管理: 包括新生报到单的发放、 检索等功能。
l 新生缴费管理: 包括新生缴费数据的录入、 检索等功能。
l 新生住宿管理: 包括新生住宿数据的录入、 修改等功能。
基本要求: 学生能够先到所在的系与有关老师联系, 进行需求调查, 然后画出新生报到管理系统数据流图, 功能流程图, 数据库的设计。再进行程序设计、 调试, 以达到本系统的功能要求。
(2) 学校教材管理系统
功能要求: 本系统能对学校所有班级的教材进行征订, 教材的入库、 出库进行管理、 能进行各种条件的查询, 打印, 还应具有教材库存预警机制( 教材库存不够用或教材征订过剩, 都能给予提示) 。
基本要求: 学生能够首先到学校教材科进行需求调查, 然后画出教材管理系统数据流图, 功能流程图, 数据库的设计。再进行程序设计、 调试, 以达到本系统的功能要求。
(3) 高校学生成绩管理系统
功能要求: 学生成绩管理是教学管理的一个重要环节, 本系统能够进行学生成绩登记、 成绩的更正、 成绩的查询、 成绩的汇总及排序、 对已毕业学生成绩能存入历史库中, 对于保存一定年限的成绩能进行清除。要求有良好的界面, 具有良好实用性。
基本要求: 学生能够先到所在的系与有关老师联系, 进行需求调查, 然后画出成绩管理系统数据流图, 功能流程图, 数据库的设计。再进行程序设计、 调试, 以达到本系统的功能要求。
(4) 高校学生学籍管理系统
该系统主要应具有以下基本功能:
l 学生管理: 包括学生数据的录入、 修改、 删除、 查询功能。
l 课程管理: 包括课程数据的录入、 修改、 删除、 查询功能。
l 教师管理: 包括教师基本数据的录入、 修改、 检索、 统计功能。
l 成绩管理: 包括学生成绩数据的录入、 修改、 查询、 统计等功能。
l 授课管理: 包括教师讲授课程、 授课地点和授课学期
基本要求: 学生能够先到所在的系与有关老师联系, 进行需求调查, 然后画出学籍管理系统数据流图, 功能流程图, 数据库的设计。再进行程序设计、 调试, 以达到本系统的功能要求。
( 5) 教务管理系统
功能要求: 教务管理是教学管理的一个重要环节, 本系统能够进行学生信息管理、 班级信息管理、 学生选课管理及选课管理。要求有良好的界面, 具有良好实用性。
基本要求: 学生能够先到所在的系与有关老师联系, 进行需求调查, 然后画出教务管理系统数据流图, 功能流程图, 数据库的设计。再进行程序设计、 调试, 以达到本系统的功能要求。
十一、 SQL语言练习
以《数据库技术》课堂教材实例练习为主, 建立学生管理数据库SM与学生表Student、 课程表Course、 选课表SC。
要求学生表中不能低于10条记录, 课程表中不能低于5条记录, 选课表中每个学生不能低于2门课程。
1. 数据查询练习
( 1) 查询姓陈的同学的信息;
( 2) 统计女生的总人数;
( 3) 查询选修课程在3门以上的学生的学号和选课门数;
( 4) 查询选课人数在30人以上的课程编号;
( 5) 统计每门课程的平均成绩及选课人数;
( 6) 查找姓名的第二个字符是”建”而且只有三个字符的学生的学号、 姓名。
( 7) 查找姓名以”王”开头的所有学生的学号、 姓名。
( 8) 查找姓名以刘、 王或崔开头的所有学生的学号、 姓名。
( 9) 查找姓名不是以刘、 王或崔开头的所有学生的学号、 姓名。
( 10) 查询无考试成绩的学生的学号和相应的课程号。
( 11) 查询有考试成绩(即成绩不为空值)的学生的学号、 课程号。
( 12) 求学生的总人数
( 13) 求选修了课程的学生人数
( 14) 求选修了课程代号为1001的学生的平均成绩。
( 15) 求学号为” 01”学生的考试总成绩之和。
( 16) 选修了1002课程的学生的最高分和最低分
( 17) 求选修每门课程的学生人数。
( 18) 求每个学生的学号和各门课程的总成绩。
( 19) 求选修课程超过2门课的学生的学号、 平均成绩, 选修的门数, 并按平均成绩降序排列。
( 20) 查询每个教师的基本信息, 并按教师编号的降序排列输出。
2.课内作业的验证
展开阅读全文