《数据库技术》课程实习指导书
一、实习课程性质和任务
《数据库技术》课程实习是在完成了理论教学和课内实训之后安排的综合实习。其目的和任务是让学生更加熟练地掌握数据库对象的基本操作、数据查询等内容,对数据库及数据库设计、SQL语言的运用,以及管理信息系统的分析、设计方法有初步了解,对管理信息系统项目的组织策划、资源管理、团队精神也有一定的认识。
《数据库技术》课程实习任务主要按照面向对象程序设计和数据库应用技术两门课程的教学内容来进行,它是以一个实际管理信息系统(MIS)的开发过程为背景来实施,实习通过一个完整的MIS项目开发,提高学生的应用开发能力及实际编程能力,使学生掌握数据库系统的基本概念、原理和应用,了解数据库系统在实际应用中的开发方法及研制过程,为今后从事管理信息系统的研究、开发、应用提供必要的知识,更好地完成各种计算机应用和开发任务。
本课程的实习分为前期准备阶段、基本操作阶段和技术提高阶段三个阶段进行:前期准备阶段的实验围绕数据库系统设计进行,它要求学生根据教科书的内容,设计一个自选的实际数据库系统,并完成相应的设计报告;基本操作阶段的实验围绕着数据库系统的基本操作进行,其内容主要是有关数据库定义、数据操纵和数据控制功能,它要求学生结合书本上有关数据库系统和数据库语言的知识完成;技术提高阶段的实验不仅要求把书本上的内容掌握好,同时还需要自学一些相关的知识。
实习的软件环境为Microsoft SQL Server 2005。 二、实习基本要求
实习采用分组方式进行,每组选定一个管理信息系统的题目,组内可以进行讨论,互相学习提高。每个组员具体做一个模块,组长负责总体协调和系统联调。在实习的过程中,要求组长带领组员深入现有系统进行深入调查,弄清用户需求。同时,要求组长督促组员都要参与开发的全过程,并鼓励组员选择MIS系统中除基本功能外的其他功能或者使用特别方法实现功能的,作为创新设计的尝试。
三、实习教学条件
⑴ 先行已开设可视化程序设计课程,并学完《数据库技术》的基本内容。 ⑵ 具备客户机/服务器模式的网络实验室作为学生实习操作的场地。
1
四、实习内容 ⑴ 系统分析与设计
要求学生掌握数据库设计的基本技术,熟悉数据库设计的每个步骤中的任务和实施方法。并加深对数据库系统概念和特点的理解。
利用数据库设计的4个阶段:需求分析(分析用户要求)、概念设计(信息分析和定义)、逻辑设计(设计实现)和物理设计(物理数据库设计)进行。概念模型设计时采用自底向上的方法,即自顶向下地进行需求分析,然后再自底向上地设计概念结构,和自底向上的设计方法。
① 用户的功能需求分析,要深入到用户和现有的实际系统中,弄清楚现有系统业务流和数据流运动过程。 ② 画出系统的功能图。 ③ 数据库系统的E-R图。
需求分析时,找出系统中的实体及实体间的关系,定义实体的必要属性、类型,域,分析实体间的关系,码及外码;画出E-R图,并将E-R关系图,按转换规则转换成关系模式,进行优化;同时实现关系及关系间的数据的有效性及完整性约束。
⑵ 管理信息系统的开发与调试
要求学生熟练掌握和使用Transact-SQL、SQL Server 对象资源管理器创建数据库、表、索引和修改表结构,并学会使用SQL Server 查询分析器接收Transact-SQL语句和进行结果分析。
① 数据库的建立:建立各种数据库表,表的主键、外键及关联等。 ② 管理信息系统界面的规划。
③ 根据管理信息系统功能模块设计,查询要方便,界面要友好。 ④ 编写各功能模块的程序代码。 ⑤ 程序的调试与联接。 五、实施办法
1. 选题:根据现实经济生活和学生生活,参考后面附录中提供的题目,要求难易适中,业务情况容易了解,涉及其他专业的“专业性”不要太强。
2
学生可以自己单独选题,或者以3-4个同学为一组共同协作进行一题目的设计小组形式选题。但一定要按本课程设计要求进行,各组题目不能重复。
2.分工要求
(1)负责工作流和功能分析,E-R图设计, 书写相应设计文档。 1人 (2)负责关系模式设计,书写相应设计文档。 1人 (3)负责前台主要模块和菜单的设计。 1-2人 六、实习学时分配
序号 1 2 3 4 5 内 容 实习动员 需求分析 上机设计 系统验收 实习材料撰写并上交 时 间 0.5天 0.5天 3天 0.5天 0.5天 5天 合计 七、实习成果
将数据库应用技术和面向对象程序设计结合起来进行实习,可以使同学们从系统的需求分析开始,经历数据库的设计、优化,到功能规划、窗体设计、界面设计、报表设计、编码、调试等整个开发过程,使同学们对MIS整个开发过程有一个较全面的认识。提高同学们的知识综合应用能力,体验学习成果,激发同学们后续课程学习兴趣。成果形式包括实习报告书、开发的管理信息系统源代码以及使用说明文档。
其中实习报告书应说明: (1)实习目的 (2)实习任务 (3)需求分析 (4)系统分析 (5)系统设计 (6)数据库设计 (7)系统实现
(8) 遇到的关键问题及解决办法
3