资源预览内容
第1页 / 共37页
第2页 / 共37页
第3页 / 共37页
第4页 / 共37页
第5页 / 共37页
第6页 / 共37页
第7页 / 共37页
第8页 / 共37页
第9页 / 共37页
第10页 / 共37页
亲,该文档总共37页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述
西北大学继续教育学院成人高等教育毕业论文题 目:教案管理系统地设计与实现指导教师:学生姓名:学号:专业:软件技术年级: 2011级学历层次:专 科学历形式:函 授完成时间:二0 年月日精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 1 页,共 37 页摘 要随着全球信息化地飞速发展,信息网络在人们地日常生活中已占据了十分重要地地位 .以往面对面地教案方式已显然不能满足现在社会地需要,逐渐也开始把信息化引入教育领域中 ,从而打破了孔家和时间地限制,为老师和学生提供了更加便捷地途径 .目前我校地教案资源库 ,具有海量地、无序地、共享性差地特点,导致了他地利用率也相当地低.各个院系都有各自地教案资源库,又导致了资源库地重复建设 ,造成了人力、物力、财力地严重浪费. 考虑到以上存在地问题 ,本文研究并设计了一套基于Web地网络教案资源管理系统 ,本系统中教师可以通过网络教授学生知识,给学生布置作业 ,完成网上批阅学生提交地作业 ,实现部分网络教案工作;学生可以通过网络学习,在网上查看并完成老师布置地作业 ,可查看本系统中提供地教案资源,岁时随思利用网络在线学习,提高学习效率 .另一方面我们集中收集并规范我校内部各个学院零散地教案资源,充分发挥本系统教案资源可以共享地优势.该系统地开发研制弥补了传统教案方式中地不足之处 ,同时减轻了我校管理人员在教案资源管理工作中地压力,有效地提高教案质量 . 本文首先接受了网络教案及教案资源地发展背景和现状并对教案资源管理系统地必要性、可行性进行了分析.根据教师、学生、教辅人员给出地需求分析,确定了系统所应具有地基本功能.采用 B/S模式和当前流行地JSP技术对系统进行开发 ,然后根据需求分析设计出系统地总体结构及分析了各个子系统地具体功能,并给出了系统部分界面和实现地部分代码.最后对论文做了总结并对该系统地进一步研究做了展望 ,明确了下一步地工作和目标. 该系统经过测试运行 ,基本达到了预期目标 .随着软件技术地不断发展和教案需要,本系统也为以后地不断更新升级留有空间.我相信本系统在我校地教案工作和管理工作中都能起到较高地实用价值和较好地应用前景. 关键词: 教案资源管理系统 ,B/S 模式,SQL Server 2005,查询精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 2 页,共 37 页目 录前言 1 第 1 章背景、目地及概述2 1.1 工程背景 2 1.2 编写目地 2 1.3 软件定义 2 1.4 开发环境 2 第 2 章需求分析 3 2.1 信息要求 3 2.2 处理要求 3 2.3 安全性与完整性要求4 第 3 章概念结果设计 5 3.1 基本 E-R图设计 5 第 4 章逻辑结构设计 8 4.1 E-R 图地转换 8 4.2 数据约束设计 9 第 5 章主要模块地设计以及代码10 5.1 登陆模块设计 11 5.2 管理员、教师、学生模块设计13 5.3 存储过程 27 5.4 触发器 27 第 6 章预测结果 29 6.1 遇到地问题以及解决方法29 6.1.1 不同对话框数据地传递29 6.1.2 数据地级联删除29 6.1.3 学生成绩地分析29 6.2 设计地体会 29 结束语 31 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 3 页,共 37 页致谢 32 参考文献 33 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 4 页,共 37 页前 言教案管理是学校运作地中心枢纽,教案管理地质量直接关系到一所高校在当代社会竞争中地地位甚至生存与发展.当今时代 ,计算机信息处理技术地广泛应用,为高校教案管理提供了有力手段.一所高等学校要走在时代地先进行列,实现教案管理工作地现代化和科学化,其关键就在于要运用现代网络信息技术建立计算机教案管理系统 ,实现管理地电脑化 .教案工作在学校地发展和建设中占有重要地位.教案管理水平地高低 ,在某种程度上反映了一所学校管理水平地整体状况.他与学校工作地其他方面有着密切地联系,对学校地教案工作、思想工作、管理工作、建设工作、教育改革以及教育方针地贯彻执行等产生重要作用与影响,而这一系列地工作有影响到整个学校地发展进程.在当前地形势下 ,随着社会地不断进步与发展,教育地现代化、规范化和管理现代化地步伐也不断加快.教育地现代化要求教案工作也应当现代化、规范化.管理现代化既包括管理思想、管理体制地现代化,也包括管理方法、管理手段地现代化.建立教案管理信息系统 ,加强计算机技术在高校教案管理中地应用,必将使高校教案管理工作更加科学化、规范化、现代化,从而大大提高高校教案管理水平. 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 5 页,共 37 页第 1 章 背景、目地及概述1.1工程背景随着科学技术、管理方法地不断进步,传统地方式、方法和手段已经不能适应现代化管理地需要 ,作为培养高质量合格人才为宗旨地高等学校,总是走在科技地最前沿 ,教案管理地计算机化已成为高校管理现代化、决策科学化地一个重要环节,是开创教案管理工作新局面地必由之路. 教案管理系统是一个辅助学校教务人员完成日常工作中,涉及学籍管理、教师管理、课程管理和成绩管理等工程地日常比较繁重地工作.它应用计算机在数据处理和数据整理保存方面地优异性能,帮助工作人员提高工作地效率、减少出错情况 .同时还能提供快速地查询检索功能. 1.2编写目地本系统地设计旨在实现管理员、教师以及学生对信息地查询、修改以及更新提供便利性 .教案管理系统是一个辅助学校教务人员完成日常工作中,涉及教师管理、课程管理和成绩管理等工程地日常比较繁重地工作.它应用计算机在数据处理和数据整理保存方面地优异性能,帮助工作人员提高工作地效率、减少出错情况. 1.3软件定义本系统做成了 C/S模式,本系统地登陆模块提供了远程连接数据库地方法,以及不同地登陆模式管理员、教师、学生),不同地登陆权限对应着可以实现操作功能是有区别地 . 1.4开发环境精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 6 页,共 37 页经过思考和选择 ,决定以 .net C#来实现本系统 . 第 2章 需求分析2.1信息要求本次系统设计主要需要地信息如下所示,这些信息都是以表地形式存在数据库中,当需要输入、删除、修改等信息时可以通过执行SQL 语句来实现 . 1、学生信息:学号、姓名、性别、出生日期、入学成绩、所在系号2、教职工信息:职工号、姓名、性别、出身年月、所在系号、职称、专业及教案方向3、系地基本信息:系号、系名称、系地简介4、课程信息:课程号、课程名称、任课教师号、学时、学分、上课时间、上课地点、考试时间5、成绩信息:学号、课程号、平时成绩、考试成绩、总评成绩2.2处理要求1、学生基本信息管理新生信息录入、学生信息修改:按学号查询出某学生地信息并做信息修改. 学生转学(转入和转出) ,学生毕业等 .毕业和转学地学生有关信息存储到历史库中 . 2、系基本信息管理:系地基本信息输入、修改、删除3、课程信息管理:课程信息地输入、修改、删除4、教职工信息管理:教职工信息地输入、修改、删除5、选课管理:每学期所选课程地学分不能超过15 分、学生可以同时选修一门或多门课程、可以同时为多个学生选修某一门或某几门课程、删除和修改选课信息 . 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 7 页,共 37 页6、成绩管理:按课程输入和修改成绩、按学生输入和修改成绩. 7、信息查询:按学号、姓名、系号查询学生基本信息. 按职工号、姓名、系号查询教职工基本信息. 按系号、系名称查询系地基本信息. 按课程号、课程名称、上课教师姓名查询课程基本信息. 按学号、学生姓名、课程号、课程名称、上课教师姓名、系号查询学生成绩,内容包括课程基本情况 .若查询涉及多门课程 ,则按课程分组 .每门课程按总评成绩从高分到低分给出选修该门课程地所有学生地成绩(平时成绩、考试成绩和总评成绩) . 8、统计报表成绩登记表 ,内容包括课程基本信息(课程号、课程名称、任课教师号、学时、学分、上课时间、上课地点、考试时间)、选课学生名单(学号、姓名、性别) ,每个学生地平时成绩(空格)、考试成绩(空格)和总评成绩(空格),按学号排序:顺序输出所有课程地成绩登记表. 按课程号、课程名称、教师姓名输出对应课程地成绩登记表. 按系号输出对应课程地成绩登记表(本系所有教师担任地课程). 成绩报表 ,内容包括课程基本信息(课程号、课程名称、任课教师号、学时、学分、上课时间、上课地点、考试时间),选课学生名单(学号、姓名、性别),每个学生地平时成绩、考试成绩和总评成绩,=90分、=80 分、 =70分、=60分及不及格学生地人数及比例,按学号排序:顺序输出所有课程地成绩报表.(报表格式自己订制 ,可以参考学校地系统地输出格式)按课程号、课程名称、教师姓名输出对应课程地成绩报表. 按系号输出对应课程地成绩报表(本系所有教师担任地课程). 2.3安全性与完整性要求在数据库中 ,各个表之间是有联系地 ,它们存在着参照完整性 ,在删除数据时 ,要考虑到一个表中地数据删除地同时也要删除另一个表中对应地数据项. 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 8 页,共 37 页第 3章 概念结果设计3.1基本 E-R 图设计E-R图设计:E-R图中实体有:教师、学生、系部、课程实体属性学生:学号、姓名、性别、出生日期、入学成绩、所在系号教师:职工号、姓名、性别、出身年月、所在系号、职称、专业及教案方向系:系号、系名称、系地简介课程:课程号、课程名称、任课教师号、学时、学分、上课时间、上课地点、考试时间其中各个之间地关系如下:学生可以选多个课程,一个课程可以被多个学生选修.学生存在一个系中 ,一个系可以存在多个学生.一个教师可以教多个课程 ,一个课程可以被多个教师教.一个教师只能在一个系中 ,一个系中可以有多个教师 . 学生:学生学号姓名性别出生日期所在系号入学成绩精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 9 页,共 37 页图 3-1 学生关系教师:图 3-2 教师关系系:图 3-3 系关系课程:图 3-4 课程关系全局 E-R 图:系信系号系名系简介课程课程号课程名教师号学时上课时间学分上课地点考试时间教师职工号姓名性别出生日期职称所在系号专 业 及 教案方向精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 10 页,共 37 页图 3-5 学生课程系教师E-R 图学生系教师课程选课系/教学 /系课教m n n 1 1 n n m 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 11 页,共 37 页第 4章 逻辑结构设计4.1 E-R图地转换表一览:Account(用户登录表)、 Course(课程表)、 Student (学生表)、 Teacher(教师表)、 Dept(系表)、 Grades( 成绩表 ). 表结构:1、Account(用户登录表)图 4-1 用户登录2、Course (课程表)图 4-2 课程3、Student (学生表)图 4-3 学生4、Teacher (教师表)精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 12 页,共 37 页图 4-4 教师5、Dept(系表)图 4-5 系6、Grades( 成绩表 ) 图 4-6 成绩4.2数据约束设计数据安全性设计:用户权限地划分. 总体设计时分为三大类用户:数据库管理员、教职工、在校学生. 其各自地权限如下:数据库管理员具有最高权限:可以对数据库中地任意数据项进行维护和更新. 教师权限:可以对Student关系表访问 ,可对 Teacher关系表进行访问 ,可以对Grades (成绩表)进行学生成绩地输入、修改和删除. 学生权限:可以对Student关系表访问 ,可对 Teacher关系表进行访问 ,可以查询某个课程地信息 ,可以对课程选课 ,以及查询自己地成绩 . 数据完整性设计:在各个关系模式设计地时候,在满足数据库涉及基本要求地同时,考虑到了外码问题 ,为后续操作想 ,各关系模式中部分表定义了外码,以便进行级联操作 . 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 13 页,共 37 页第 5章 主要模块地设计以及代码在进行各个模块地说明前有必要说明一下面向对象地程序设计思想,在本系统中,为方便对数据库地连接、SQL 语句地执行以及数据库地关闭.本程序封装了一个 SQLDatabase类,类中定义了一系列地函数来完成数据库地连接等操作. 代码及说明如下:class SQLDatabase public SqlConnection SQLConnection 。 public SqlCommand MyCommand 。 public SqlDataAdapter sdr 。 static public string ServerIP 。 public void GetServerIP(string IP) ServerIP=IP 。 public void SQLDataConnectionOpen() /本函数完成对数据库地连接 SQLConnection = new SqlConnection() 。 SQLConnection.ConnectionString = Server= + ServerIP + 。User id=sa。pwd=123456。DataBase=TeachingManagementSystem。 SQLConnection.Open() 。 public void SQLDataConnectionClose()/ 实现数据库地关闭 SQLConnection.Close() 。 public int SQLExecuteNonQuery(string str) /ExecuteNonQuery方法:执行不返回结果地命令 MyCommand = new SqlCommand(str, SQLConnection) 。 return MyCommand.ExecuteNonQuery() 。 public object SQLExecuteScalar(string str) /只返回结果集中第一行地第一列精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 14 页,共 37 页 MyCommand = new SqlCommand(str, SQLConnection) 。 return MyCommand.ExecuteScalar() 。 public SqlDataAdapter SQLDataAdapter(string strCmd) sdr = new SqlDataAdapter(strCmd, SQLConnection) 。 return sdr 。 public SqlDataReader SQLExecuteReader(string strCmd) /执行返回数据集地Select语句,返回一个 DataReader 对象 MyCommand = new SqlCommand(strCmd, SQLConnection) 。 SqlDataReader sdr = MyCommand.ExecuteReader()。 return sdr 。 5.1登陆模块设计在本程序地登陆模块中 ,当用户输入用户名、密码及其登陆权限后,会对数据与数据库地数据进行对比,若相同则进入相应地权限界面,以进行相应地操作 . 登陆界面如下图所示:图 5-1 登录登陆按钮地单击消息响应:当用户输入用户名、密码及登陆权限,单击登陆精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 15 页,共 37 页按钮后 ,数据会与数据库地数据进行对比,若相同则通过 ,否则会提示用户响应地错误报告 .代码如下:private void button1_Click(object sender, EventArgs e) if (textBox1.Text = ) MessageBox.Show(服务器 IP地址不能为空 ,请输入用户名! , 提示)。 textBox1.Focus() 。 return。 else if (textBox2.Text = ) MessageBox.Show(用户名不能为空 ,请输入用户名! , 提示)。 textBox2.Focus() 。 return。 else if (textBox3.Text = ) MessageBox.Show(密码不能为空 ,请输入密码! , 提示)。 textBox3.Focus() 。 return。 else if (textBox4.Text = ) MessageBox.Show(校验码不能为空 ,请输入! , 提示)。 textBox4.Focus() 。 return。 else if (textBox4.Text != label6.Text) MessageBox.Show(校验码输入不正确 ,请重新输入! , 提示)。 textBox4.Text = 。 label6.Text = ProduceCheckCode() 。textBox4.Focus()。return。 string identity = 0。 if (radioButton1.Checked) identity = 3。 else if (radioButton2.Checked) identity = 2 。 else if (radioButton3.Checked) identity = 1。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 16 页,共 37 页 SQLDatabase SQLConn = new SQLDatabase()。 SQLConn.GetServerIP(textBox1.Text) 。 SQLConn.SQLDataConnectionOpen() ; string strCmd = select * from Account where Aname= + textBox2.Text + and Apassword= + textBox3.Text + + and Apermissions= + identity + 。 SqlDataReader sdr = SQLConn.SQLExecuteReader(strCmd)。 int n = 0。 while (sdr.Read() n = 1。 Form2 form2 = new Form2(identity,textBox1.Text)。 form2.Show()。this.Hide()。 if (n = 0) MessageBox.Show(没有此用户! n 或者用户名或密码错误! n 请重新输入或者注册当前用户!, 提示)。 label6.Text = ProduceCheckCode() 。 sdr.Close() 。 SQLConn.SQLDataConnectionClose() 。 另外本模块也提供了校验码认证、用户注册功能. 用户单击登陆按钮后 ,系统会对用户输入地校验码与系统随机生成地校验码进行对比 ,不相同会提示用户重新输入. 当用户想注册一个账户时 ,系统会根据用户输入地用户名、密码、权限,在数据库中查找是否已存在相同地用户名若相同则提示用户注册成功,否则提示用户错误报告 .代码与登陆响应类似不再列出. 5.2管理员、教师、学生模块设计这里需要说明一点地是 ,本程序地操作端是通过TabControl控件实现地 ,各个tabPage页都放在了一个对话框上 ,对于不同地登陆权限 ,会在对话框地初始化函精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 17 页,共 37 页数中通过调用 tabControl1.TabPages.Remove() 。函数来实现某个 tabPage页地隐藏,以体现不同地权限功能 . 所以这里只需要对管理员端地各个操作进行说明即可,整个界面如下图所示:图 5-2 管理员、教师、学生tabPage1 :学生管理在学生管理页面中 ,管理员可以对学生信息进行查询、删除、修改、录入、及其转学 /毕业操作等 . 另外,各个表之间是有联系地 ,当删除一个学生地信息后,如果此学生选了课 ,并且有了成绩 ,系统会同时把此学生地选课记录、成绩记录删除. 当录入一个学生地信息时 ,系统提供了判断机制 ,系统会先检查数据库中是否已存在该学生地信息 ,若存在提示不同录入 . 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 18 页,共 37 页其 录入 按钮地单击消息响应函数代码为:private void button1_Click(object sender, EventArgs e) if (textBox1.Text = ) MessageBox.Show( 学号不能为空 ,请输入学号!, 提示 )。 textBox1.Focus() 。return。 else if (textBox2.Text = ) MessageBox.Show( 姓名不能为空 ,请输入姓名! , 提示 )。 textBox2.Focus() 。 return。 string sex= 。 if(radioButton1.Checked) sex=男。 else if (radioButton2.Checked) sex=女。 SQLDatabase SQLConn = new SQLDatabase() 。 SQLConn.GetServerIP(SerIP) 。 SQLConn.SQLDataConnectionOpen() 。 string strCmd 。 string strCmd2 。 string strCmd3 。 strCmd = insert into Student values( + textBox1.Text + , + textBox2.Text + , +sex+ ,+textBox3.Text+,+textBox4.Text+,+textBox5.Text+)。 strCmd2 = select * from Student where Sno= + textBox1.Text + 。 strCmd3 = select * from Dept where Dno= + textBox5.Text + 。 object ob = SQLConn.SQLExecuteScalar(strCmd2) 。 if (Convert.ToString(ob) != ) MessageBox.Show( 已存在学号为 + textBox1.Text + 地信息! n请重新输入!, 提示 )。 textBox1.Text = 。 textBox2.Text = 。 textBox3.Text = 。 textBox4.Text = 。 textBox5.Text = 。 textBox1.Focus() 。 SQLConn.SQLDataConnectionClose() 。 return。 object ob1 = SQLConn.SQLExecuteScalar(strCmd3) 。 if (Convert.ToString(ob1) = ) if (textBox5.Text != ) 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 19 页,共 37 页 MessageBox.Show( 不存在系号为 + textBox5.Text + 地系信息!n请重新输入! , 提示 )。 textBox5.Text = 。 textBox5.Focus() 。 SQLConn.SQLDataConnectionClose() 。 return。 SQLConn.SQLExecuteNonQuery(strCmd) 。 MessageBox.Show( 录入成功! , 提示 )。 /控件清空! textBox1.Text = 。 textBox2.Text = 。 textBox3.Text = 。 textBox4.Text = 。 textBox5.Text = 。 textBox1.Focus() 。 SQLConn.SQLDataConnectionClose() 。 button5_Click(sender, e) 。 tabPage2 :系管理在系管理页面中 ,管理员可以对系信息进行查询、删除、修改、输入. 另外,各个表之间是有联系地 ,当删除一个系地信息后 ,在该系地所以学生记录会同时删除 ,与此相应地选课、成绩记录也会被删除. 当录入一个系地信息时 ,系统提供了判断机制 ,系统会先检查数据库中是否已存在该系地信息 ,若存在提示不同录入 . 其 输入 按钮地单击消息响应函数代码为:private void button7_Click(object sender, EventArgs e) if (textBox7.Text = ) MessageBox.Show( 系号不能为空 ,请输入系号!, 提示 )。 textBox7.Focus() 。 return。 else if (textBox8.Text = ) MessageBox.Show( 系名不能为空 ,请输入系名!, 提示 )。 textBox8.Focus() 。 return。 SQLDatabase SQLConn = new SQLDatabase() 。 SQLConn.GetServerIP(SerIP) 。 SQLConn.SQLDataConnectionOpen() 。 string strCmd 。 string strCmd2 。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 20 页,共 37 页 strCmd = insert into Dept values( + textBox7.Text + , + textBox8.Text + , + textBox9.Text + ) 。 strCmd2 = select * from Dept where Dno= + textBox7.Text + 。 object ob = SQLConn.SQLExecuteScalar(strCmd2) 。 if (Convert.ToString(ob) != ) MessageBox.Show( 已存在系号为 + textBox7.Text + 地信息! n请重新输入!, 提示 )。 textBox7.Text = 。 textBox8.Text = 。 textBox9.Text = 。 textBox7.Focus() 。 SQLConn.SQLDataConnectionClose() 。 return。 else SQLConn.SQLExecuteScalar(strCmd) 。 MessageBox.Show( 输入成功! , 提示 )。 /控件清空! textBox7.Text = 。 textBox8.Text = 。 textBox9.Text = 。 textBox7.Focus() 。 SQLConn.SQLDataConnectionClose() 。 button10_Click(sender,e) 。 tabPage3 :课程管理在课程管理页面中 ,管理员可以对课程信息进行查询、删除、修改、输入. 另外,各个表之间是有联系地 ,当删除一个课程地信息后,选择此课程地选课记录,成绩记录也会被同时删除. 当录入一个课程地信息时 ,系统提供了判断机制 ,系统会先检查数据库中是否已存在该课程地信息 ,若存在提示不同录入 . 其 输入 按钮地单击消息响应函数代码为:private void button12_Click(object sender, EventArgs e) if (textBox10.Text = ) MessageBox.Show( 课程号不能为空,请输入课程号!, 提示 )。 textBox10.Focus() 。 return。 else if (textBox11.Text = ) MessageBox.Show( 课程名不能为空,请输入课程名!, 提示 )。 textBox11.Focus() 。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 21 页,共 37 页 return。 else if (textBox12.Text = ) MessageBox.Show( 任课教师号不能为空,请输入课程名!, 提示 )。 textBox12.Focus() 。 return。 SQLDatabase SQLConn = new SQLDatabase() 。 SQLConn.GetServerIP(SerIP) 。 SQLConn.SQLDataConnectionOpen() 。 string strCmd 。 string strCmd2 。 strCmd = insert into Course values( + textBox10.Text + , + textBox11.Text + , + textBox12.Text + , + textBox13.Text + , + textBox14.Text+ , + textBox15.Text + , + textBox16.Text + , + textBox17.Text + )。 strCmd2 = select * from Course where Cno= + textBox10.Text + 。 object ob = SQLConn.SQLExecuteScalar(strCmd2) 。 if (Convert.ToString(ob) != ) MessageBox.Show( 已存在课程号为 + textBox10.Text + 地信息! n请重新输入!, 提示 )。 textBox10.Text = 。 textBox11.Text = 。 textBox12.Text = 。 textBox13.Text = 。 textBox14.Text = 。 textBox15.Text = 。 textBox16.Text = 。 textBox17.Text = 。 textBox10.Focus() 。 SQLConn.SQLDataConnectionClose() 。 return。 string strCmd3 = select * from Teacher where Tno= + textBox12.Text + 。 object ob1 = SQLConn.SQLExecuteScalar(strCmd3) 。 if (Convert.ToString(ob1) = ) if (textBox12.Text != ) MessageBox.Show( 不存在教师号为 + textBox12.Text + 地教师信息! n请重新输入! , 提示 )。 textBox12.Text = 。 textBox12.Focus() 。 SQLConn.SQLDataConnectionClose() 。 return。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 22 页,共 37 页 SQLConn.SQLExecuteNonQuery(strCmd) 。 MessageBox.Show( 课程信息输入成功!, 提示 )。 /控件清空! textBox10.Text = 。 textBox11.Text = 。 textBox12.Text = 。 textBox13.Text = 。 textBox14.Text = 。 textBox15.Text = 。 textBox16.Text = 。 textBox17.Text = 。 textBox10.Focus() 。 SQLConn.SQLDataConnectionClose() 。 button14_Click( sender, e) 。 tabPage4 :教师管理在教师管理页面中 ,管理员可以对教师信息进行查询、删除、修改、输入. 当录入一个教师地信息时 ,系统提供了判断机制 ,系统会先检查数据库中是否已存在该教师地信息 ,若存在提示不同录入 . 其 输入 按钮地单击消息响应函数代码为:private void button17_Click(object sender, EventArgs e) if (textBox6.Text = ) MessageBox.Show( 职工号不能为空,请输入! , 提示 )。 textBox6.Focus() 。 return。 else if (textBox18.Text = ) MessageBox.Show( 姓名不能为空 ,请输入! , 提示 )。 textBox18.Focus() 。 return。 else if (textBox20.Text = ) MessageBox.Show( 所在系号不能为空,请输入! , 提示 )。 textBox20.Focus() 。 return。 string sex = 。 if (radioButton11.Checked) sex = 男。 else sex = 女。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 23 页,共 37 页 SQLDatabase SQLConn = new SQLDatabase() 。 SQLConn.GetServerIP(SerIP) 。 SQLConn.SQLDataConnectionOpen() 。 string strCmd 。 string strCmd2 。 strCmd = insert into Teacher values( + textBox6.Text + , + textBox18.Text + , + sex + , + textBox19.Text + , + textBox20.Text + , + textBox21.Text + , + textBox22.Text + , + textBox23.Text + )。 strCmd2 = select * from Teacher where Tno= + textBox6.Text + 。 。 object ob = SQLConn.SQLExecuteScalar(strCmd2) 。 if (Convert.ToString(ob) != ) MessageBox.Show( 已存在职工号为 + textBox6.Text + 地信息! n请重新输入! , 提示 )。 textBox6.Text = 。 textBox19.Text = 。 textBox20.Text = 。 textBox21.Text = 。 textBox22.Text = 。 textBox23.Text = 。 textBox6.Focus() 。 SQLConn.SQLDataConnectionClose() 。 return。 string strCmd3 = select * from Dept where Dno= + textBox20.Text + 。 object ob1 = SQLConn.SQLExecuteScalar(strCmd3) 。 if (Convert.ToString(ob1) = ) if (textBox20.Text != ) MessageBox.Show( 不存在系号为 + textBox20.Text + 地系信息!n请重新输入! , 提示 )。 textBox20.Text = 。 textBox20.Focus() 。 SQLConn.SQLDataConnectionClose() 。 return。 SQLConn.SQLExecuteNonQuery(strCmd) 。 MessageBox.Show( 职工信息输入成功!, 提示 )。 /控件清空! textBox6.Text = 。 textBox18.Text = 。 textBox19.Text = 。 textBox20.Text = 。 textBox21.Text = 。 textBox22.Text = 。 textBox23.Text = 。 textBox6.Focus() 。 SQLConn.SQLDataConnectionClose() 。 button19_Click(sender,e) 。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 24 页,共 37 页 tabPage5 :选课管理在选课管理页面中 ,管理员可以对选课信息进行查询、删除、修改、输入. 当录入一个选课地信息时 ,系统提供了判断机制 ,系统会先检查数据库中是否已存在该选课地信息 ,若存在提示不同录入 . 其 提交 按钮地单击消息响应函数代码为:private void button22_Click(object sender, EventArgs e) if (textBox24.Text = ) MessageBox.Show( 学号不能为空 ,请输入! , 提示 )。 textBox24.Focus() 。 return。 else if (textBox25.Text = ) MessageBox.Show( 课程号不能为空,请输入! , 提示 )。 textBox25.Focus() 。 return。 if(textBox24.Text.Contains(,)=true|textBox24.Text.Contains(,)=true) CourseManyStudent( sender, e)。 return。 if(textBox25.Text.Contains(,)=true|textBox25.Text.Contains(,)=true) StudentManyCourse( sender, e)。 return。 SQLDatabase SQLConn = new SQLDatabase() 。 SQLConn.GetServerIP(SerIP) 。 SQLConn.SQLDataConnectionOpen() 。 string strCmd1, strCmd2, strCmd3, strCmd4, strCmd5 。 string credits= 。 strCmd1 = select * from Student where Sno= + textBox24.Text + 。 strCmd2 = select * from Course where Cno=+textBox25.Text+。 strCmd3 = select Sno,Cno from CourseSelectionTable where Sno= + textBox24.Text + and Cno= + textBox25.Text + 。 。 strCmd4 = select Ccredits from Course where Cno= + textBox25.Text + 。 object ob1, ob2, ob3, ob4。 ob1 = SQLConn.SQLExecuteScalar(strCmd1) 。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 25 页,共 37 页 if (Convert.ToString(ob1) = ) if (textBox24.Text != ) MessageBox.Show( 不存在学号为+textBox24.Text+ 地学生信息!n请重新输入! , 提示 )。 textBox24.Text = 。 textBox24.Focus() 。 SQLConn.SQLDataConnectionClose() 。 return。 ob2 = SQLConn.SQLExecuteScalar(strCmd2) 。 if (Convert.ToString(ob2) = ) if (textBox25.Text != ) MessageBox.Show( 不存在课程号为 + textBox25.Text + 地课程信息! n请重新输入! , 提示 )。 textBox25.Text = 。 textBox25.Focus() 。 SQLConn.SQLDataConnectionClose() 。 return。 ob4 = SQLConn.SQLExecuteScalar(strCmd4) 。 credits = ob4.ToString() 。 strCmd5 = insert into CourseSelectionTable values( + textBox24.Text + , + textBox25.Text + , + credits + )。 ob3 = SQLConn.SQLExecuteScalar(strCmd3) 。 if (Convert.ToString(ob3) != ) MessageBox.Show( 已存在学号为 + textBox24.Text + 课程号为 + textBox25.Text + 地信息! n请重新输入!, 提示 )。 textBox24.Text = 。 textBox25.Text = 。 textBox24.Focus() 。 SQLConn.SQLDataConnectionClose() 。 return。 double sum = TotalCredit(textBox24.Text) 。 if (Convert.ToDouble(credits)+sum)=15) MessageBox.Show( 选择此课程后,总学分将超过15,不能再选课!, 提示 )。 SQLConn.SQLDataConnectionClose() 。 button25_Click(sender, e) 。 return。 else SQLConn.SQLExecuteNonQuery(strCmd5) 。int ZongSum=(int)(Convert.ToDouble(credits)+sum)。 string CcreditsSum = 选课信息提交成功!n学号为 + textBox24.Text + n地学生选精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 26 页,共 37 页课地总学分为: +ZongSum.ToString() 。 MessageBox.Show(CcreditsSum, 提示 )。 SQLConn.SQLDataConnectionClose() 。 button25_Click(sender, e) 。 tabPage6 :成绩管理在成绩管理页面中 ,管理员可以对成绩信息进行查询、删除、修改、输入. 当录入一个成绩地信息时 ,系统提供了判断机制 ,系统会先检查数据库中是否已存在该选课地信息 ,若存在提示不能输入 . 另外当输入一个学生地成绩时,系统会从选课表中查找是否该学生选了此课程若没有选 ,则提示用户不能输入该学生地成绩信息. 其 提交 按钮地单击消息响应函数代码为:private void button27_Click(object sender, EventArgs e) if (textBox27.Text = ) MessageBox.Show( 学号不能为空 ,请输入! , 提示 )。 textBox27.Focus() 。 return。 else if (textBox28.Text = ) MessageBox.Show( 课程号不能为空,请输入! , 提示 )。 textBox28.Focus() 。 return。 if (textBox29.Text = ) textBox29.Text = 0 。 if (textBox30.Text = ) textBox30.Text = 0 。 SQLDatabase SQLConn = new SQLDatabase() 。 SQLConn.GetServerIP(SerIP) 。 SQLConn.SQLDataConnectionOpen() 。 string strCmd1, strCmd2, strCmd3, strCmd4 。 double totalresults 。 totalresults = Convert.ToDouble(textBox29.Text) * 0.3 + Convert.ToDouble(textBox30.Text) * 0.7。 textBox31.Text = totalresults.ToString() 。 strCmd1 = select * from Student where Sno= + textBox27.Text + 。 strCmd2 = select * from Course where Cno= + textBox28.Text + 。 strCmd3 = select Gsno,Gcno from Grades where Gsno= + textBox27.Text + and Gcno= + textBox28.Text + 。 strCmd4 = insert into Grades values( + textBox27.Text + , + textBox28.Text + , + 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 27 页,共 37 页textBox29.Text + , + textBox30.Text + , + totalresults.ToString() + )。 object ob1, ob2, ob3 。 ob1 = SQLConn.SQLExecuteScalar(strCmd1) 。 if (Convert.ToString(ob1) = ) if (textBox27.Text != ) MessageBox.Show( 不存在学号为 + textBox27.Text + 地学生信息! n请重新输入! , 提示 )。 textBox27.Text = 。 textBox27.Focus() 。 SQLConn.SQLDataConnectionClose() 。 return。 ob2 = SQLConn.SQLExecuteScalar(strCmd2) 。 if (Convert.ToString(ob2) = ) if (textBox28.Text != ) MessageBox.Show( 不存在课程号为 + textBox28.Text + 地课程信息! n请重新输入! , 提示 )。 textBox28.Text = 。 textBox28.Focus() 。 SQLConn.SQLDataConnectionClose() 。 return。 string strCmd5 。 strCmd5 = select * from CourseSelectionTable where Sno= + textBox27.Text + and Cno= + textBox28.Text + 。 object ob4。 ob4 = SQLConn.SQLExecuteScalar(strCmd5) 。 if (Convert.ToString(ob4) = ) if (textBox27.Text != &textBox28.Text!=) MessageBox.Show( 该学生没有选课程号为+textBox28.Text+ 地课程!不能输入成绩! , 提示 )。 textBox27.Text = 。 textBox28.Text = 。 textBox29.Text = 。 textBox30.Text = 。 textBox31.Text = 。 textBox27.Focus() 。 SQLConn.SQLDataConnectionClose() 。return。 ob3 = SQLConn.SQLExecuteScalar(strCmd3) 。 if (Convert.ToString(ob3) != ) 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 28 页,共 37 页 MessageBox.Show( 已存在学号为 + textBox27.Text + 课程号为 + textBox28.Text + 地成绩信息! n请重新输入! , 提示 )。 textBox27.Text = 。 textBox28.Text = 。 textBox29.Text = 。 textBox30.Text = 。 textBox31.Text = 。 textBox27.Focus() 。 SQLConn.SQLDataConnectionClose() 。 return。 SQLConn.SQLExecuteNonQuery(strCmd4) 。MessageBox.Show(成绩信息输入成功!, 提示)。SQLConn.SQLDataConnectionClose() 。 ShowListView() 。 button29_Click(sender, e) 。 button33_Click( sender, e) 。 tabPage7 :报表在报表页面中 ,管理员可以通过报表地显示来查看学生地成绩登记表、成绩报表. 界面如下:精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 29 页,共 37 页图 5-3 报表在程序中利用了 listView 控件来实现 =90分、=80分、 =70 分、 =60分及不及格学生地人数及比例地显示,其函数地代码为:private void ShowListView() int temp = 0 。 int n = 0 。 float sum = 0 。 int records = new int 0, 0, 0, 0, 0 。 string str = select Ggradesshould from Grades 。 SQLDatabase SQLConn = new SQLDatabase() 。 SQLConn.GetServerIP(SerIP) 。 SQLConn.SQLDataConnectionOpen() 。 SqlDataReader sdr = SQLConn.SQLExecuteReader(str) 。 while (sdr.Read() sum+。 n = (int)Convert.ToDouble(sdrGgradesshould.ToString()。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 30 页,共 37 页 temp = n / 10。 switch (temp) case 10: case 9: records0+ 。 break。 case 8: records1+ 。 break。 case 7: records2+ 。 break。 case 6: records3+ 。 break。 default: records4+ 。 break。 listView1.Items.Clear() 。 string Itemstr = =90, 80-89, 70-79, 60-69, 不及格 。 SQLConn.SQLDataConnectionClose() 。/.ConnectionClose() 。 float note = new float5。 for (int i = 0 。 i 15 begin rollback transaction end 实现学生成绩信息地修改:create trigger GradesInsertUpdate on Grades for insert,update as update Grades set Gusuallyresults=100,Gtestscores=100,Ggradesshould=100*0.3+100*0.7 where Gusuallyresults100 and Gtestscores100 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 32 页,共 37 页第 6章 预测结果6.1遇到地问题以及解决方法在编写此程序时 ,主要遇到了以下几个方面地问题:6.1.1不同对话框数据地传递解决方法:在弹出第二个对话框时,需要把服务器地 IP 地址以及登陆用户地权限传递到第二个对话框中,实现地方法是在为第二个对话框显示时通过传递两个参数来实现地代码为:Form2 form2 = new Form2(identity,textBox1.Text)。 form2.Show()。6.1.2数据地级联删除因为各个表是有联系地 ,在删除一个数据时有时候也需要把另一个表地数据也要删除 ,这可以通过在创建表时加上以下两句以实现级联删除:on delete cascade on update cascade 6.1.3学生成绩地分析在程序中需要对学生地总成绩进行统计,这是通过调用自定义地一个函数来实现地 ,在函数中通过对数据库进行读取学生地总成绩,并进行记数以确定总学生数,如何对此成绩所属地成绩段进行记数以确定此成绩段地总学生数,最后再用成绩段地学生数去除总学生数,进而得到不同成绩段地百分比. 6.2设计地体会本程序地设计主要是通过使用TabControl控件来实现各个功能模块地,在TabControl控件地页面上通过添加各个控件进一步实现对数据库中数据地删除、修改以及添加等 . 在登录用户地权限方面 ,显示出地是同一个对话框,但是根据用户地权限 ,在对话框地初始化函数中通过使某些页面显示与隐藏以及某些按钮地显示与隐藏来实现不同地登陆权限 . 在报表方面 ,由于对报表不是很熟悉 ,刚开始并不清楚如何利用报表来实现数据地显示以及图表地美化,通过查找资料 ,对报表地设计已经满足了课设地要求.精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 33 页,共 37 页本程序在报表中插入地图表主要是用来显示成绩比例地,在设计时需要在“图表专家”地“数据”标签下进行一些数据地定义,这里需要定义 5个“定义命令组”( =90 分、=80 分、 =70 分、=60 分及不及格)以实现各个学生总成绩地统计 . 另一方面 ,在对数据库中地数据进行操作时,需要考虑到各个表中数据之间地联系.例如,在删除一个学生地信息时,如果此学生选了课并且有了该课程地成绩,那么在删除此学生信息时需要同时把选课、成绩信息删除,这就需要进行表中数据地级联删除 . 总地来说 ,此次数据库课设 ,通过自己对课设题目地理解,进而实现程序地整体架构 ,对各个功能模块进行设计后,还是学到了不少地东西 . 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 34 页,共 37 页结束语教案管理系统地实现 ,通过多方面地测试是可行地.通过 myEclipse 工具开发该系统 ,更熟练地掌握该工具地使用. 熟练地运用 MVC 框架技术 ,在编程地过程中 ,减少大量地代码 .Hibernate技术主要掌握 JavaBean与关系数据库地映射关系,一对一、一对多 ,减少了重复去写数据库连接; Spring技术主要掌握控制反转和依赖注入,以及applicationContext.xml 地配置 .控制层中 ,主要掌握 JSf技术,熟练地运用了 JSF地组件. 该系统中 ,有些功能实现了 ,但不是特别地完善 .要具体地完善 ,需要对 css样式有所了解 ,这样做出来地系统更加完善.Css样式正在学习当中 ,该系统也会在我学习当中完善 . 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 35 页,共 37 页致 谢大学专科生活即将画上一个句号,在这紧张而丰富地三年学习和生活过程中,在各位老师和同学地帮助下,我获益匪浅 .本论文地完成也正是我这一学习阶段地总结.在此谨向所有支持、关心和帮助过我地老师、同学、朋友以及家人致以最诚挚地感谢 . 首先要感谢我地指导老师赵文娟老师,本论文是在赵老师地精心指点下完成地 ,导师严谨求实地治学态度、渊博地专业知识、丰富地实践经验、前瞻开阔地科学视野、孜孜不倦地敬业精神和诲人不倦地长者风范,给我影响至深 ,足以使我受益终身 ,也培养了我独立工作地能力和不畏挑战地创新精神.在完成论文中地工作时 ,得到了导师地悉心指点和谆谆教诲,在此向赵老师表示最诚挚地敬意和衷心地感谢 ! 感谢学院能给我提供学习地机会,感谢全体老师在我学习过程中给予我地指导和帮助 ,特别感谢论文答辩委员会地诸位老师能在百忙之中审阅我地论文,并出席论文答辩会 . 感谢和我共同走过三年学习生活地舍友、同学给我地支持和鼓励. 感谢我地家人 ,学业地完成离不开你们地支持,没有你们无私地奉献和默默支持,没有你们在我遇到困难时地激励和帮助,我是不可能顺利完成学业地,在此,谨表衷心感谢 !最后,再一次感谢所有给我帮助、支持和关心地人们!祝愿你们永远幸福、快乐 ! 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 36 页,共 37 页参考文献1 萨师烜 . 数据库系统概论. 高等教育出版社2 杨长春 .Delphi程序设计教程. 清华大学出版社3 刘卫国 . 等数据库技术与应用. 清华大学出版社4 石志国 .ASP.NET实用案例教程. 清华大学山版社.2003 年 7 月5 周桓 .JSP 工程开发全程实录M. 北京:清华大学出版社.2008 6 李洋 .NET 平台在教案资源管理系统中地应用J.福建电脑 ,2010 (6): 84-85 7 李莹 . 基于校园网地教案资源管理系统地设计与研究J.科技广场 .2006.11 :84-86 8 董西尚 . 基于Web地网络教案辅助系统地设计与实现J.茂名学院学报,2010 (10):57-59 9 卢汉鹏等 .JSP 开发技术详解 M. 北京:化学工业出版社.2010 10 陈志超 . 浅谈现代远程开放教育网络平台下教案资源管理系统地构建及应用J 11 褚洪彦 . 基于 Web地校际专业教案资源管理系统设计与实现J 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 37 页,共 37 页
收藏 下载该资源
网站客服QQ:2055934822
金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号