学生选课系统课程设计

合集下载

学生选课系统c课程设计

学生选课系统c课程设计

学生选课系统c 课程设计一、教学目标本课程旨在让学生掌握学生选课系统C的基本原理和使用方法。

知识目标包括了解学生选课系统的功能、结构和常用技术,理解面向对象设计的基本概念和方法。

技能目标包括能够使用学生选课系统C进行课程选择和排课,能够进行简单的系统设计和优化。

情感态度价值观目标包括培养学生对编程和计算机科学的兴趣和热情,提高学生解决问题的能力和创新精神。

二、教学内容本课程的教学内容主要包括学生选课系统C的基本原理、系统结构和常用技术,面向对象设计的基本概念和方法,以及学生选课系统C的实践应用。

具体包括以下几个部分:1.学生选课系统C的基本原理:介绍学生选课系统C的定义、功能和特点,让学生了解学生选课系统C的基本概念。

2.学生选课系统C的系统结构:讲解学生选课系统C的组成部分,包括数据库、服务器和客户端等,让学生了解学生选课系统C的架构和运行机制。

3.学生选课系统C的常用技术:介绍学生选课系统C中常用的技术,如SQL、Java等,让学生掌握学生选课系统C的开发和实现方法。

4.面向对象设计的基本概念和方法:讲解面向对象设计的基本原则和方法,如封装、继承和多态等,让学生掌握面向对象设计的思维方式和实际应用。

5.学生选课系统C的实践应用:通过实际操作,让学生学会使用学生选课系统C进行课程选择和排课,培养学生的实际操作能力。

三、教学方法为了提高教学效果,本课程将采用多种教学方法相结合的方式进行教学。

包括:1.讲授法:通过讲解学生选课系统C的基本原理、系统结构和常用技术,让学生掌握基本概念和知识。

2.讨论法:通过学生进行小组讨论,引导学生思考和探讨学生选课系统C的实际应用问题和解决方案。

3.案例分析法:通过分析典型案例,让学生了解学生选课系统C的实际应用场景和设计方法。

4.实验法:通过实际操作,让学生学会使用学生选课系统C进行课程选择和排课,培养学生的实际操作能力。

四、教学资源为了支持本课程的教学,我们将准备以下教学资源:1.教材:选择合适的教材,为学生提供系统的学习资料。

学生选课系统课程设计c

学生选课系统课程设计c

学生选课系统课程设计c一、教学目标本课程旨在让学生掌握学生选课系统的设计与实现。

知识目标方面,学生需要理解数据库的基本概念、SQL语言、关系型数据库的设计原理;技能目标方面,学生需要能够使用一种编程语言实现学生选课系统的核心功能;情感态度价值观目标方面,学生需要培养团队协作意识,增强对计算机科学和软件工程的兴趣。

二、教学内容本课程的教学内容主要包括四个部分:数据库理论、SQL语言、关系型数据库设计、学生选课系统实现。

其中,数据库理论主要介绍数据库的基本概念、数据模型、关系型数据库的规范化;SQL语言主要讲解数据定义语言、数据操纵语言、数据查询语言;关系型数据库设计主要阐述如何根据需求设计合理的数据库表结构;学生选课系统实现主要分析系统的功能模块、实现方法以及测试与优化。

三、教学方法为了提高学生的学习兴趣和主动性,本课程将采用多种教学方法。

首先,通过讲授法向学生传授基本概念和理论知识;其次,利用讨论法激发学生对问题的思考和探讨;再者,采用案例分析法让学生通过分析实际案例,加深对知识的理解和应用;最后,运用实验法让学生动手实践,培养实际操作能力。

四、教学资源为了支持教学内容和教学方法的实施,丰富学生的学习体验,我们将准备以下教学资源:教材《数据库原理与应用》、参考书《SQL语言教程》、《关系型数据库设计》、多媒体资料(包括教学视频、PPT等)、实验设备(计算机、数据库服务器等)。

五、教学评估本课程的教学评估将采用多元化方式,全面客观地评价学生的学习成果。

评估方式包括平时表现、作业、考试等。

平时表现主要评估学生的课堂参与度、讨论积极性及团队协作能力;作业则主要评估学生对知识的理解和应用能力;考试则全面考察学生的理论知识掌握和实际操作技能。

评估过程将保持公正、客观,确保每一位学生的努力都能得到合理的回报。

六、教学安排本课程的教学安排将遵循合理、紧凑的原则,确保在有限的时间内完成教学任务。

教学进度将根据课程内容和学生的实际情况进行调整,以保证教学效果。

学生选课管理系统c课程设计

学生选课管理系统c课程设计

学生选课管理系统c 课程设计一、课程目标知识目标:1. 让学生理解学生选课管理系统的基本概念和功能,掌握系统设计的基本原理。

2. 使学生掌握数据库的基本操作,如查询、插入、删除和更新数据。

3. 帮助学生了解软件开发流程,熟悉系统设计、编码、测试等环节。

技能目标:1. 培养学生运用所学知识,独立设计并实现一个简单的学生选课管理系统。

2. 提高学生分析问题和解决问题的能力,学会运用数据库技术解决实际应用问题。

3. 培养学生的团队协作能力,学会在项目中进行有效沟通和分工合作。

情感态度价值观目标:1. 培养学生积极的学习态度,激发学生对计算机科学的兴趣和热情。

2. 培养学生的创新意识和实践能力,鼓励学生勇于尝试,敢于挑战。

3. 增强学生的责任心,让学生明白系统设计的重要性,关注用户需求,为用户带来更好的体验。

本课程针对高年级学生,课程性质为理论与实践相结合。

在教学过程中,注重培养学生的实际操作能力和解决问题的能力。

结合学生特点和教学要求,将课程目标分解为具体的学习成果,以便进行后续的教学设计和评估。

通过本课程的学习,使学生能够掌握学生选课管理系统设计的相关知识和技能,为今后从事软件开发和数据库管理等相关工作打下坚实基础。

二、教学内容1. 学生选课管理系统的基本概念与功能- 系统需求分析- 功能模块划分2. 数据库基础知识- 数据库设计原则- 数据表创建与维护- 数据查询、插入、删除和更新操作3. 系统设计- 系统架构设计- 界面设计- 数据库连接与操作4. 编程实现- 编程语言选择(如Java、Python等)- 系统功能编码- 代码调试与优化5. 系统测试与维护- 测试方法与策略- 常见问题分析与解决- 系统维护与升级6. 项目实践- 团队协作与分工- 项目进度管理- 系统部署与展示教学内容根据课程目标制定,涵盖学生选课管理系统设计的相关知识。

本课程采用教材相关章节,结合实际案例,保证教学内容的科学性和系统性。

c学生选课管理系统课程设计

c学生选课管理系统课程设计

c 学生选课管理系统课程设计一、课程目标知识目标:1. 学生能够理解学生选课管理系统的基本概念和功能,掌握系统设计的基本原理。

2. 学生能够描述数据库的基本结构,了解数据表之间的关系,并运用SQL语句进行数据查询和操作。

3. 学生能够了解软件工程的基本流程,包括需求分析、系统设计、编码实现和测试等环节。

技能目标:1. 学生能够运用结构化分析方法进行需求分析,独立设计学生选课管理系统的功能模块。

2. 学生能够使用数据库设计工具,创建数据库和表,编写SQL查询语句,实现数据的有效管理。

3. 学生能够运用编程语言(如Java、C#等)实现学生选课管理系统的部分功能,具备基本的编程实践能力。

情感态度价值观目标:1. 培养学生独立思考、解决问题的能力,增强团队合作意识和沟通能力。

2. 培养学生对信息技术的兴趣和热情,提高学生的信息素养,使他们对信息技术的发展保持关注。

3. 培养学生具备诚信、负责的态度,认识到信息技术对社会发展的重要影响,树立正确的价值观。

课程性质:本课程为信息技术学科,旨在培养学生掌握学生选课管理系统设计与实现的基本技能,提高学生的编程实践能力和信息素养。

学生特点:学生具备一定的计算机操作能力和编程基础,对信息技术有一定的兴趣。

教学要求:注重理论与实践相结合,以项目为导向,培养学生动手实践能力和解决问题的能力。

将课程目标分解为具体的学习成果,以便于教学设计和评估。

二、教学内容1. 学生选课管理系统概述:介绍学生选课管理系统的基本概念、功能模块及其在实际应用中的重要性。

- 教材章节:第一章 绪论2. 需求分析:讲解如何运用结构化分析方法进行需求分析,包括用例图、活动图等工具的使用。

- 教材章节:第二章 需求分析3. 数据库设计:介绍数据库的基本概念、关系型数据库的设计方法,以及SQL 语言进行数据操作。

- 教材章节:第三章 数据库设计4. 系统设计:讲解系统设计的基本原理,包括软件架构、模块划分、界面设计等。

c学生选课管理系统课程设计

c学生选课管理系统课程设计

c 学生选课管理系统课程设计一、教学目标本课程旨在让学生了解和掌握学生选课管理系统的基本原理和实现方法。

通过本课程的学习,学生将能够:1.理解学生选课管理系统的需求和功能。

2.掌握学生选课管理系统的基本架构和模块设计。

3.学会使用相关技术和工具实现学生选课管理系统的各个功能。

4.培养学生的团队合作能力和问题解决能力。

二、教学内容本课程的教学内容主要包括以下几个部分:1.学生选课管理系统概述:介绍学生选课管理系统的定义、需求和功能。

2.系统设计:讲解学生选课管理系统的基本架构和模块设计。

3.技术实现:介绍实现学生选课管理系统各个功能所需要使用的技术和工具。

4.系统测试与优化:讲解如何对 student course selection managementsystem 进行测试和优化。

三、教学方法为了提高学生的学习兴趣和主动性,本课程将采用多种教学方法,包括:1.讲授法:讲解基本概念、原理和关键技术。

2.案例分析法:分析实际案例,让学生更好地理解学生选课管理系统的应用。

3.实验法:让学生通过动手实践,加深对课程内容的理解和掌握。

四、教学资源为了支持教学内容和教学方法的实施,本课程将准备以下教学资源:1.教材:为学生提供全面、系统的理论知识。

2.参考书:提供更多的背景知识和实际案例。

3.多媒体资料:通过视频、图片等形式,丰富学生的学习体验。

4.实验设备:为学生提供实践操作的机会,加深对课程内容的理解和掌握。

五、教学评估本课程的评估方式包括平时表现、作业和考试三个部分。

平时表现主要评估学生的课堂参与度和团队合作能力,占总评的30%。

作业主要包括课后练习和项目任务,占总评的40%。

考试为闭卷考试,评估学生对课程知识的掌握程度,占总评的30%。

六、教学安排本课程共32课时,安排在第8至第16周的每周二、四下午2:00-4:00进行。

教学地点为计算机实验室,以确保学生有足够的实践操作机会。

教学进度安排合理紧凑,确保在有限的时间内完成教学任务。

学生选课系统c课程设计

学生选课系统c课程设计

学生选课系统c 课程设计一、课程目标知识目标:1. 让学生理解学生选课系统的基本概念,掌握其功能模块和使用方法;2. 使学生掌握数据库查询、数据传递和界面设计的相关知识;3. 帮助学生了解编程规范,提高代码质量。

技能目标:1. 培养学生运用所学知识设计并实现一个简单的学生选课系统的能力;2. 培养学生分析问题、解决问题的能力;3. 提高学生的团队协作能力和沟通能力。

情感态度价值观目标:1. 激发学生对计算机科学的兴趣,培养其探索精神;2. 引导学生树立正确的价值观,认识到编程在解决实际问题中的作用;3. 培养学生面对挑战保持积极态度,勇于克服困难。

课程性质:本课程为实践性较强的课程,结合课本知识,通过设计一个学生选课系统,使学生将所学理论知识运用到实际项目中。

学生特点:学生处于高年级阶段,已具备一定的编程基础,对数据库和编程有初步了解,但实际项目经验较少。

教学要求:注重理论与实践相结合,以学生为主体,充分调动学生的积极性和主动性,培养其创新精神和实践能力。

通过课程学习,使学生在掌握知识的同时,提高自身技能和情感态度价值观。

教学过程中,将课程目标分解为具体的学习成果,便于教学设计和评估。

二、教学内容1. 学生选课系统概述:介绍学生选课系统的基本概念、功能模块及其在实际中的应用。

- 教材章节:第1章 数据库系统概述2. 数据库设计与实现:讲解如何设计学生选课系统的数据库,包括表结构设计、数据关系等。

- 教材章节:第2章 数据库设计基础3. 编程语言与开发环境:介绍使用C语言或C++进行学生选课系统开发,讲解开发环境的配置和使用。

- 教材章节:第3章 C/C++编程基础4. 界面设计与实现:教授如何设计和实现用户界面,包括界面布局、功能模块划分等。

- 教材章节:第4章 界面设计与实现5. 系统功能实现:分析学生选课系统各功能模块的实现方法,包括选课、退课、查询课程等。

- 教材章节:第5章 数据库应用开发6. 测试与优化:讲解如何对系统进行测试、调试和优化,保证系统稳定性和性能。

c学生选课系统课程设计

c学生选课系统课程设计

c 学生选课系统课程设计一、教学目标本课程的学习目标包括以下三个方面:1.知识目标:学生需要掌握学生选课系统的基本概念、原理和流程,了解系统的各个模块和功能,以及相关的前端和后端技术。

2.技能目标:学生能够独立完成学生选课系统的搭建和部署,具备对系统进行维护和优化的能力,能够使用相关的开发工具和软件进行系统开发。

3.情感态度价值观目标:学生通过本课程的学习,能够增强对计算机科学和信息技术的兴趣和热情,培养良好的科学素养和创新精神,提升解决实际问题的能力。

在制定教学目标时,我们分析了课程性质、学生特点和教学要求,将目标分解为具体的学习成果,以便后续的教学设计和评估。

二、教学内容根据课程目标,我们选择和了以下教学内容:1.学生选课系统的概述:包括系统的定义、功能、特点和应用场景。

2.学生选课系统的设计:包括系统的架构、模块设计、数据库设计和界面设计。

3.学生选课系统的实现:包括前端开发、后端开发、系统测试和优化。

4.学生选课系统的部署和维护:包括系统的部署方法、维护策略和常见问题解决。

以上内容涵盖了学生选课系统的各个方面,确保了教学内容的科学性和系统性。

三、教学方法为了激发学生的学习兴趣和主动性,我们选择了以下教学方法:1.讲授法:通过讲解和演示,使学生了解学生选课系统的相关概念和原理。

2.讨论法:学生进行小组讨论,培养学生的思考能力和团队合作精神。

3.案例分析法:分析实际案例,使学生更好地理解和掌握学生选课系统的应用。

4.实验法:让学生亲自动手进行系统开发和实验,提高学生的实践能力。

四、教学资源我们选择了以下教学资源,以支持教学内容和教学方法的实施:1.教材:选用权威、实用的教材,为学生提供系统的理论知识。

2.参考书:提供丰富的参考资料,帮助学生拓展知识面。

3.多媒体资料:制作精美的PPT、视频等资料,提高学生的学习兴趣。

4.实验设备:提供充足的实验设备,保证学生能够顺利进行实验操作。

以上教学资源将丰富学生的学习体验,提高教学质量。

c课程设计学生选课系统

c课程设计学生选课系统

c课程设计学生选课系统一、教学目标本课程的目标是让学生掌握学生选课系统的开发和应用,包括对其原理和实现的理解,以及如何使用该系统进行选课。

•理解学生选课系统的基本原理和架构。

•掌握常用的选课算法和策略。

•熟悉学生选课系统的开发工具和技术。

•能够独立设计和实现一个简单的学生选课系统。

•能够对现有的学生选课系统进行评估和改进。

•能够使用相关的开发工具和技术进行学生选课系统的开发。

情感态度价值观目标:•培养学生的创新意识和团队合作精神,使他们能够在团队中发挥自己的专长,共同完成一个学生选课系统的设计和实现。

•培养学生对技术的热爱和敬业精神,使他们能够持续学习和跟进最新的技术动态,不断提高自己的技能水平。

二、教学内容本课程的教学内容主要包括学生选课系统的原理、选课算法、系统设计、开发工具和技术。

1.学生选课系统的原理:介绍学生选课系统的基本概念、架构和运作机制,包括选课流程、课程分类、学生选课策略等。

2.选课算法:讲解常用的选课算法,如先到先得、最大匹配、最小匹配等,并通过实例进行讲解和分析。

3.系统设计:介绍学生选课系统的系统设计,包括需求分析、模块设计、数据库设计等,并通过实际案例进行讲解和分析。

4.开发工具和技术:介绍学生选课系统的开发工具和技术,如编程语言、数据库管理系统、前端技术等,并通过实际操作进行讲解和演示。

三、教学方法本课程将采用讲授法、讨论法、案例分析法和实验法等多种教学方法进行教学。

1.讲授法:通过讲解和演示,使学生了解学生选课系统的原理、算法、设计和开发工具等技术内容。

2.讨论法:通过学生进行小组讨论,培养他们的团队合作意识和解决问题的能力。

3.案例分析法:通过分析实际案例,使学生更好地理解和掌握学生选课系统的原理和设计方法。

4.实验法:通过实际操作和实验,使学生掌握学生选课系统的开发工具和技术,并培养他们的动手能力。

四、教学资源本课程将使用教材、参考书、多媒体资料和实验设备等教学资源。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

滨江学院软件工程课程设计报告( 2007 -- 2008 年度第二学期)课程名称:软件工程课程设计题目:学生选课系统院系:软件工程班级:学号:姓名:指导教师:设计周数:两周日期:2008 年7月4日摘要:本系统实现学生选课的基本功能,包括学生退选课,查看自己的选课信息;教师查看选课学生的信息,提交成绩;管理员添加学生、管理学生、管理成绩、添加教师、管理教师和管理课程等。

系统利用.Net平台技术进行开发,实现学生选课的动态管理,使得对信息的管理更加及时、高效,提高了效率。

同时还对系统的开发原理、功能特点和设计方案进行了介绍。

关键词:学生选课数据库管理 一、课程设计的目的与要求通过软件开发的实践训练,进一步掌握软件工程的方法和技术,提高软件开发的实际能力,培养工程设计能力和综合分析、解决问题的能力。

具体如下:1.学习和实践在分析和设计计算机应用系统所需要的知识,包括面向对象的系统分析与设计,编码和测试方面的知识;2.熟悉自动化的软件开发工具Rational Rose 2003,并将其运用于软件开发的全过程;3.进一步加强和提高软件工程文档的编写能力;4.培养协作能力和团队精神。

二、设计正文1.概述1.1课题题目:学生选课系统1.2系统的主要目标:本系统目标是实现选课系统所需的各种基本功能,包括学生选课、退课功能和教师查看选修课程、提交课程成绩功能以及管理员添加学生、维护学生信息、成绩管理、添加教师、维护教师信息、维护选修课程,还有公用的修改密码等功能。

1.3 系统的开发环境及运行环境:操作系统:Windows XP Pro SP2建模工具:Rational Rose 2003数据库系统:SQL Server2000开发工具:Visual Studio 2005Web服务器:IIS+ 2.0平台2.系统需求分析学生选课系统主要满足来自三方面的需求,这三个方面分别是学生用户、教师用户和管理员用户,也即是三类用户角色。

(1)学生用户是主要的需求者,主要需求功能是查询可选课程、查看自己选课情况及进行选课、退课操作等;(2)教师用户主要需求功能是查看自己所教授的课程、课程有哪些学生选修、以及利用本系统提交学生的成绩;(3)管理员用户的功能需求较为复杂,包括对学生信息、教师信息、课程信息进行管理。

在学生信息管理子模块中,实现对学生信息的添加、修改、删除操作,还可以输入查询条件进行查询操作。

在教师管理子模块中,实现对教师信息的添加、修改、删除、查询等操作。

在课程管理子模块中,实现对课程信息的添加,添加时为其分配任课教师、上课时间和地点,实现对课程的修改、删除、查看某个课程的详细信息等。

本系统将管理员用户、教师用户、学生用户的身份及权限进行严格的划分,让管理员拥有最高权限,可以查看、维护系统中的所有信息,如添加学生,添加课程,修改课程信息等;让教师拥有查看自己开设的课程的信息,以及提交所开设课程成绩的权限;让学生拥有选课和退选的权限;而修改密码模块的权限每个用户都可拥有,用以修改自己的密码信息。

通过进行严格的权限划分,可以更好地进行管理,也可更好地保护用户信息安全。

2.1用例图图2-1 学生选课系统用例图用例图说明:(1)系统的外部角色有:学生用户、教师用户和管理员。

(2)系统主要用例的文档描述:①学生管理用例:学生用户可见的功能,包含了选课、退课和查看选课三个用例功能。

②教师管理用例:教师用户可见的功能,包含了查看学生选课和提交成绩两个用例功能。

③信息管理用例:管理员可见的功能,这个用例进一步分为三个用例:学生信息管理用例、④学生信息管理用例:信息管理用例可见的功能,实现学生信息的管理功能,包含了添加学生、修改学生信息和删除学生三个用例。

⑤教师信息管理用例:信息管理用例可见的功能,实现教师信息的管理功能,包含了添加教师、修改教师信息和删除教师三个用例。

⑥课程信息管理用例:信息管理用例可见的功能,实现课程信息的管理功能,包含了添加课程、修改课程信息和删除课程三个用例。

⑦修改密码用例:所有用户都可见的功能,用于修改用户的密码信息。

(3)系统用例之间的关系:①学生管理用例与选课、查看选课、退课三用例之间是包含关系。

②教师管理用例与查看学生选课、提交成绩两用例之间是包含关系。

③信息管理用例与学生信息管理用例、教师信息管理用例和课程信息管理用例之间是包含关系。

④学生信息管理用例与添加学生、修改学生信息和删除学生三个用例之间是包含关系。

⑤教师信息管理用例与添加教师、修改教师信息和删除教师三个用例之间是包含关系。

⑥课程信息管理用例与添加课程、修改课程信息和删除课程三个用例之间是包含关系。

(4)系统关键用例的正常事件流图和异常事件流图表2-1 修改密码用例的正常事件流图和异常事件流图表2-2 提交成绩用例的正常事件流图和异常事件流图用例名称提交成绩用例参与者教师用户描述提交选自己开设课程的学生的成绩启动进入提交成绩界面前置条件用户成功登录后置条件尚未提交过成绩主事件流用户系统1.单击提交成绩2.系统提交成绩页面3.填写学生成绩,单击提交成绩5.更新学生成绩,提示提交成功异常流异常流用户已经提交过该门课程成绩系统提示该课程成绩已提交,不能再次提交2.2类图图2-2 学生选课系统类图类图说明:(1)BaseUser类是一个系统角色用户的基类,主要方法有两个:modifyPWD() 用于修改用户的密码;loginCheck() 用于用户登录验证。

(2)Admin类继承自BaseUser类。

(3)Student类继承自BaseUser类,主要方法有:studentAdd() 用于添加学生;studentDel() 用于删除学生;studentUpdate() 用于更新学生信息;getStudents() 用于获取学生列表。

(4)Teacher类继承自BaseUser类,主要方法有:teacherAdd() 用于添加教师;teacherDel() 用于删除教师;teacherUpdate() 用于更新教师信息;getTeachers() 用于获取教师列表。

(5)Course类是一个课程类,主要方法有:courseAdd() 用于添加课程;courseDel() 用于删除课程;courseUpdate() 用于修改课程信息;getCourses() 用于获取课程列表。

(6)Elect类是一个选课表类,主要方法有:elect() 选修课程;electDel() 退选课程;getElectInfo() 获取选课信息;haveSubmit() 检测是否已提交过成绩;submitScore() 提交成绩。

2.3顺序图(1) 管理员修改课程信息顺序图: 管理员(2) 学生用户退选课的顺序图图2-4 学生用户退选课的顺序图(3) 教师提交成绩顺序图图2-5 教师提交成绩顺序图: 教师用户2.4协作图(可选)(1) 学生用户选课协作图图2-6 学生用户选课协作图(2) 教师提交成绩协作图图2-7 教师提交成绩协作图3.系统总体设计3.1 设计问题域子系统学生选课系统是实现学生选课退课、教师提交成绩以及学校教务管理员维护信息的一个平台,整个学生选课系统有前台和后台两部分,共分为4个模块:管理员模块,教师模块,学生模块和公有模块,分别用于完成各自的功能。

以下为学生选课系统总体设计图和各功能模块说明:(1)总体设计图(2)各模块功能表3-1 学生选课系统功能模块表3.2 设计数据管理子系统(1)数据库表表3-2 数据库表序号数据库表数据表存储的内容1 Student 存储学生的信息2 Teacher 存储教师的信息3 Users 存储管理员的信息4 Elect 存储选课的信息5 Cource 存储课程的信息6 Depart 存储学校系院信息(2)数据表之间的关系图3-2 数据表之间的关系图(3)数据库表结构①学生表Student的详细数据字段:②教师表Teacher的详细数据字段:③课程表Course的详细数据字段:④选课表Elect的详细数据字段:⑤系统管理员表Users的详细数据字段:⑥系院表Depart的详细数据字段:3.3 设计人机交互子系统(1)用户分类本系统的用户可分为三类:①管理员用户;②教师用户;③学生用户。

(2)用户描述①管理员用户的描述:管理员用户在整个选课系统中起到管理和维护的作用,对学生和教师的信息进行管理和维护以及开设课设等职责。

②教师用户的描述:教师用户在本系统中具有管理选修了自己开设的课程的学生的权限,查看选修了自己开设课程的学生信息有及提交学生成绩。

③学生用户的描述:选课系统主要是针对管理学生的,学生在本系统中具有修改自己的信息,以及选课和退选的功能。

(3)设计命令层次①系统的人机交互子系统的内容和准则:本学生选课系统的人机交互子系统在根据不同的用户身份登陆到不同的页面,然后按照不同的用户只能进行用户权限内的操作,其结构图如下:②通过采用树形结构,细化命令的组织方式,如下:4.详细设计学生选课系统是实现学生网上选课、教师提交成绩以及学校教务管理员维护信息的一个平台,整个学生选课系统共分为4个大模块:管理员模块,教师模块,学生模块和公有模块,其中复杂的方法和模块的详细设计流程图如下。

4.1系统用户登录流程图图4-1 系统用户登录流程图4.2 用户密码修改流程图图4-2 用户密码修改流程图4.3教师提交成绩流程图图4-3教师提交成绩流程图4.4管理员添加课程流程图图4-4 管理员添加课程流程图4.5学生选修课程流程图图4-5 学生选修课程流程图5.系统实现本系统采用了三层架构来实现,即分为用户界面层(UI)、业务逻辑层(BLL)和数据访问层(DAL),用户界面层是展示给用户的界面,方便用户与系统进行交互;业务逻辑层是对系统业务实体的封装,完成系统业务功能;数据访问层直接与数据库打交道,为业务逻辑层提供底层的数据库操作。

5.1 Database类主要是与数据库连接,提供数据库操作功能,代码如下:namespace MyElectCourse.DAL{public class Database{protected string connectionString;protected SqlConnection connection = null;public Database(){connectionString =ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString.ToString();}~Database(){if (connection != null){connection = null;}}protected void Open(){if (connection == null){connection = new SqlConnection(connectionString);}if (connection.State.Equals(ConnectionState.Closed)){connection.Open();}}protected void Close(){if (connection != null){connection.Close();}}public int ExecuteSQL(string sqlstr){int count = -1;this.Open();SqlCommand cmd = new SqlCommand(sqlstr, connection);count = cmd.ExecuteNonQuery();this.Close();return count;}public DataSet GetDataSet(string sqlstr){this.Open();DataSet ds = new DataSet();SqlDataAdapter adapter = new SqlDataAdapter(sqlstr,connection);adapter.Fill(ds);this.Close();return ds;}public DataTable GetDataTable(string sqlstr){DataSet ds = this.GetDataSet(sqlstr);DataTable dt = new DataTable();if (ds.Tables.Count > 0){dt = ds.Tables[0];}return dt;}public SqlDataReader GetDataReader(string sqlstr){this.Open();SqlCommand cmd = new SqlCommand(sqlstr, connection);SqlDataReader sdr = cmd.ExecuteReader(CommandBehavior.CloseConnection);//this.Close();return sdr;}}}5.2 UserBase类是所有系统角色用户的基类,完成用户登录验证与修改密码的功能,代码如下:namespace MyElectCourse.BLL{public class UserBase{private string userID;public string UserID{get { return userID; }set { userID = value; }}private string userPSW;public string UserPSW{get { return userPSW; }set { userPSW = value; }}public string loginCheck(string uid, string upwd, string urole){String selectStr = String.Empty;switch (urole){case"0": //身份为教师时selectStr = "Select * from Teacher where teaID = '" + uid + "'";break;case"1": //身份为学生时selectStr = "Select * from Student where stuID = '" + uid + "'";break;case"2": //身份为管理员时selectStr = "Select * from Users where adminName = '" + uid + "'";break;default:return null;}Database db = new Database();DataTable dt = db.GetDataTable(selectStr);if (dt.Rows.Count > 0) //如果该用户存在{if (dt.Rows[0][1].ToString().Equals(upwd)) //密码正确{switch (urole){case"0": //身份为教师时return"0";case"1": //身份为学生时return"1";case"2": //身份为管理员时return"2";default:return null;}}else//密码错误,给出提示信息!{return"-1";}}else//用户不存在或用户名输入错误{return"-2";}}public string modifyPWD(String urole, String uid, String oldPwd, String newPwd){String updateStr = String.Empty;switch (urole){case"0": //身份为教师时updateStr = "update Teacher set teaPwd='" + newPwd + "' where teaID='" + uid + "'";break;case"1": //身份为学生时updateStr = "update Student set stuPwd='" + newPwd + "' where stuID='" + uid + "'";break;case"2": //身份为管理员时updateStr = "update Users set adminPwd='" + newPwd + "' where adminName='"break;}string ucheck = this.loginCheck(uid, oldPwd, urole);if (ucheck.Equals("0") || ucheck.Equals("1") || ucheck.Equals("2")){int t = new Database().ExecuteSQL(updateStr); //根据修改后返回的结果给出提示if (t > 0){return"1";}else{return"0";}}else{return"-1";} } }}5.3 系统登录页面,代码及运行效果如下:<head runat="server"><title>登录页面</title></head><body onload="document.all.txtUserName.focus()"leftmargin="0"rightmargin="0"><form id="form1"runat="server"><div><table align="center"style="font-size: 12px; font-family: Tahoma; border-collapse: collapse"<tr><td colspan="2"style="text-align: center"><span style="font-size: 24pt; font-family: 隶书">学生选课系统</span></td></tr><tr><td><div align="right"><span style="font-family: 宋体">用户名</span>:</div></td><td style="width: 242px"><asp:TextBox ID="txtUserName"runat="server"Width="150px"></asp:TextBox><asp:RequiredFieldValidator ID="RequiredFieldValidator1"runat="server" ErrorMessage="不能为空!"></asp:RequiredFieldValidator></td></tr><tr><td style="height: 32px"><div align="right">密&nbsp;&nbsp;&nbsp;码:</div></td><td style="height: 32px; width: 242px;"><asp:TextBox ID="txtPwd"runat="server"TextMode="Password"<asp:RequiredFieldValidator ID="RequiredFieldValidator2"runat="server"ErrorMessage="不能为空!"></asp:RequiredFieldValidator></td></tr><tr><td colspan="2"align="center"style="height: 46px"><asp:RadioButtonList ID="rblClass"runat="server"RepeatDirection="Horizontal"><asp:ListItem Value="0">教师</asp:ListItem><asp:ListItem Selected="True"Value="1">学生</asp:ListItem><asp:ListItem Value="2">管理员</asp:ListItem></asp:RadioButtonList><asp:Label ID="lblMessage"runat="server"ForeColor="Red"></asp:Label></td></tr><tr><td align="center"colspan="2"><asp:ImageButton ID="imgbtnLogin"runat="server"ImageUrl="~/Images/Login.GIF"<asp:ImageButton ID="imgbtnClose"runat="server"ImageUrl="~/Images/Close.GIF"</td></tr></table></div></form></body></html>图5-1系统登录页面5.4 学生用户选课界面代码及运行效果图如下:<html xmlns="/1999/xhtml"><head runat="server"><title>学生选课</title></head><body leftmargin="0"rightmargin="0"topmargin="0"><form id="form1"runat="server"><div><table width="100%"bgcolor="#ccccff"><tr><td><uc1:top ID="Top1"runat="server"/></td></tr></table><table id="table1"width="80%"border="0"align="center"><tr><td align="center"><span style="font-size: 16pt;">可选修课程</span></td></tr><tr><td><asp:GridView ID="GridView1"runat="server"AutoGenerateColumns="False" BackColor="White"Width="100%"BorderColor="#999999"BorderStyle="None"BorderWidth="1px" CellPadding="3"DataSourceID="SqlDataSource1"GridLines="Vertical"OnRowCommand="GridView1_RowCommand"Font-Size="10pt"DataKeyNames="courceID,teaID"><FooterStyle BackColor="#CCCCCC"ForeColor="Black"/><RowStyle BackColor="#EEEEEE"ForeColor="Black"Font-Size="10pt"/><SelectedRowStyle BackColor="#008A8C"Font-Bold="True"ForeColor="White"/><PagerStyle BackColor="#999999"ForeColor="Black"HorizontalAlign="Center" /><HeaderStyle BackColor="Blue"Font-Bold="True"ForeColor="White"Font-Size="10pt"/><AlternatingRowStyle BackColor="Gainsboro"/><Columns><asp:BoundField DataField="courceID"HeaderText="courceID"ReadOnly="True"Visible="False"SortExpression="courceID"/><asp:BoundField DataField="teaID"Visible="False"HeaderText="teaID" ReadOnly="True"SortExpression="teaID"/><asp:BoundField DataField="courceName"HeaderText="课程名称" SortExpression="courceName"></asp:BoundField><asp:BoundField DataField="teaName"HeaderText="教师姓名" SortExpression="teaName"></asp:BoundField><asp:BoundField DataField="courceTime"HeaderText="上课时间" SortExpression="courceTime"></asp:BoundField><asp:BoundField DataField="courceAddress"HeaderText="上课地点" SortExpression="courceAddress"></asp:BoundField><asp:HyperLinkField DataNavigateUrlFields="courceID,teaID" DataNavigateUrlFormatString="courseDetail.aspx?courceID={0}&teaID={1}"HeaderText="详细..."Text="详细..."/><asp:ButtonField HeaderText="选修"CommandName="select"Text="选修"></asp:ButtonField></Columns></asp:GridView><asp:SqlDataSource ID="SqlDataSource1"runat="server"ConnectionString="<%$ ConnectionStrings:ConnectionString %>"SelectCommand="SELECT Cource.courceID, Cource.teaID, Cource.courceName, Teacher.teaName, Cource.courceTime, Cource.courceAddress FROM Cource INNER JOIN Teacher ON Cource.teaID = Teacher.teaID WHERE NOT EXISTS (SELECT * FROM Elect WHERE (courceID=Cource.courceID and teaID=Cource.teaID and stuID = @stuID))"><SelectParameters><asp:SessionParameter Name="stuID"SessionField="userID"/></SelectParameters></asp:SqlDataSource></td></tr><tr><td><asp:Label runat="server"ID="errormess"ForeColor="Red"Font-Size="Smaller"></asp:Label></td></tr><tr><td style="height: 24px; text-align: center"><span style="font-size: 16pt;">您已经选修的课程</span></td></tr><tr><td><asp:GridView ID="GridView2"runat="server"AutoGenerateColumns="False" BackColor="White"Width="100%"BorderColor="#999999"BorderStyle="None"BorderWidth="1px" CellPadding="3"DataSourceID="SqlDataSource2"GridLines="Vertical"OnRowCommand="GridView2_RowCommand"DataKeyNames="stuID,courceID,teaID"><FooterStyle BackColor="#CCCCCC"ForeColor="Black"/><RowStyle BackColor="#EEEEEE"ForeColor="Black"Font-Size="10pt"/><SelectedRowStyle BackColor="#008A8C"Font-Bold="True"ForeColor="White"/><PagerStyle BackColor="#999999"ForeColor="Black"HorizontalAlign="Center" /><HeaderStyle BackColor="Blue"Font-Bold="True"ForeColor="White"Font-Size="10pt"/><AlternatingRowStyle BackColor="Gainsboro"/><Columns><asp:BoundField DataField="stuID"HeaderText="stuID"ReadOnly="True" SortExpression="stuID"Visible="False"/><asp:BoundField DataField="courceID"HeaderText="courceID"ReadOnly="True"SortExpression="courceID"Visible="False"/><asp:BoundField DataField="teaID"HeaderText="teaID"ReadOnly="True"SortExpression="teaID"Visible="False"/><asp:BoundField DataField="courceName"HeaderText="课程名称"SortExpression="courceName"><asp:BoundField DataField="teaName"HeaderText="教师姓名"SortExpression="teaName"></asp:BoundField> <asp:BoundField DataField="courceTime"HeaderText="上课时间"SortExpression="courceTime"><asp:BoundField DataField="courceAddress"HeaderText="上课地点"SortExpression="courceAddress"> <asp:ButtonField HeaderText="退选"CommandName="shanchu"Text="退选</Columns></asp:GridView><asp:SqlDataSource ID="SqlDataSource2"runat="server"ConnectionString="<%$ ConnectionStrings:ConnectionString %>"SelectCommand="SELECT Elect.stuID,Elect.courceID, Elect.teaID,<SelectParameters><asp:SessionParameter Name="stuID"SessionField="userID"/></SelectParameters></asp:SqlDataSource><td style="height: 21px"align="center"><asp:HyperLink ID="HyperLink1"runat="server"NavigateUrl="~/ModifyPwd.aspx"Font-Size="10pt">修改密码</asp:HyperLink><asp:HyperLink ID="HyperLink2"runat="server"Font-Size="10pt"NavigateUrl="javascript:window.close()">退出系统</asp:HyperLink></td></tr></table></div></form></body></html>图5-2 学生选课界面5.5 教师用户提交成绩界面代码及运行效果如下:<head runat="server"><title>提交成绩</title></head><body leftmargin="0"rightmargin="0"topmargin="0"><form id="form1"runat="server"><div><table width="100%"bgcolor="#ccccff"><tr><td><uc1:top ID="Top1"runat="server"/></td></table><table id="table1"width="400"border="0"runat="server"align="center"><tr valign="top"><td align="left"><asp:Label ID="lblmessage"Font-Size="10pt"runat="server">课程名称:&nbsp;&nbsp;</asp:Label><asp:TextBox runat="server"ID="cname"></asp:TextBox></td></tr><tr><td align="center"><asp:GridView ID="GridView1"runat="server"AutoGenerateColumns="False" BackColor="White"BorderColor="#999999"BorderStyle="None"BorderWidth="1px"CellPadding="3" Font-Size="10pt"GridLines="Vertical"Width="100%"><FooterStyle BackColor="#CCCCCC"ForeColor="Black"/><Columns><asp:BoundField DataField="stuID"HeaderText="学号"/><asp:BoundField DataField="stuName"HeaderText="姓名"/><asp:BoundField DataField="stuGrade"HeaderText="年级"/><asp:BoundField DataField="stuClass"HeaderText="班级"/><asp:TemplateField HeaderText="成绩"><ItemTemplate><asp:TextBox ID="txtScore"Width="30"runat="server"></asp:TextBox></ItemTemplate></asp:TemplateField></Columns><RowStyle BackColor="#EEEEEE"Font-Size="10pt"ForeColor="Black"/><SelectedRowStyle BackColor="#008A8C"Font-Bold="True"ForeColor="White"/><PagerStyle BackColor="#999999"ForeColor="Black"HorizontalAlign="Center" /><HeaderStyle BackColor="Blue"Font-Bold="True"ForeColor="White"/><AlternatingRowStyle BackColor="Gainsboro"/></asp:GridView></td></tr><tr><td align="center"><asp:ImageButton ID="imgBtnSubmitScore"runat="server" ImageUrl="~/Images/SubmitScore.GIF"OnClick="imgBtnSubmitScore_Click"/></td></tr><tr><td><asp:Label runat="server"ID="mess"Font-Size="Smaller" ForeColor="Red"></asp:Label></td></tr><tr><td align="center"><asp:HyperLink ID="HyperLink1"runat="server"Font-Size="10pt" NavigateUrl="teacherQueryElect.aspx">查看选课</asp:HyperLink>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<asp:HyperLink ID="HyperLink2"runat="server"Font-Size="10pt" NavigateUrl="~/ModifyPwd.aspx">修改密码</asp:HyperLink></td></tr></table></div><br/></form></body></html>图5-3 教师用户提交成绩界面5.6 管理员用户添加课程代码及运行效果如下:<html xmlns="/1999/xhtml"><head runat="server"><title>课程详细信息</title></head><body leftmargin="0"rightmargin="0"><form id="form1"runat="server"><div align="center"><table style="font-size: 12px; font-family: Tahoma; border-collapse: collapse"id="table"width="450"border="0"runat="server"><tr><td align="center"><asp:Label ID="courceName"runat="server"Font-Size="16"ForeColor="red"></asp:Label><font size="4">&nbsp;&nbsp;的详细信息</font><br/><asp:Label ID="lblMessage"runat="server"ForeColor="Red"></asp:Label></td></tr><tr height="25"align="left"><td style="height: 25px"><br><b>课程名称:<asp:TextBox ID="txtName"runat="server"></asp:TextBox></b></td></tr><tr height="25"align="left"><td><b>教师姓名:<asp:TextBox ID="teaName"runat="server"></asp:TextBox></b></td></tr><tr height="25"align="left"><td style="height: 25px"><b>上课时间:<asp:TextBox ID="txtTime"runat="server"></asp:TextBox></b></td></tr><tr height="25"align="left"><td><b>上课地点:<asp:TextBox ID="txtAddress"runat="server"></asp:TextBox></b></td></tr><tr height="10"><td><hr size="1"></td></tr><tr><td align="left"><b>课程简介:</b><br/><asp:TextBox ID="txtDetails"runat="server"Height="100px"Width="100%"TextMode="MultiLine"BorderColor="Transparent"BorderStyle="Groove"BorderWidth="1px"Font-Size="9pt"></asp:TextBox></td></tr></table></div><br/></form></body></html>图5-4 管理员添加课程界面6.系统测试在系统测试中,我们首先对各个子模块进行单元测试,即把每一个模块作为一个单独的实体来测试,保证每个模块作为一个单元能正确运行。

相关文档
最新文档