1、网上智能评教系统的开发摘要本文详细阐述了网上智能评教系统(以下简称系统)的设计与实现。系统以Visual 2003 中的 C#.net 为开发语言,数据库采用 SQL Server 2000。系统的智能性主要体现在智能动态设计评选项目、动态生成评教界面、智能设置非法评教结果特征、根据学生学号智能提取被评教的教师名单、对单个评教结果智能分析(主要是指对合法的和非法的结果的不同处理) 、评教结束后智能统计出没有参与评教的学生名单、根据评教结果对教师智能评分等。服务器端操作系统使用 Windows Server 2003,每秒数据库并发数据访问记录数在 5002000 ,具有较高的稳定性,较好的维
2、护水平。【关键词】教学评估,智能评教,非法处理,智能评分1The Development of Online Intelligent Teacher-Comment SystemAbstractThis text has explained the design and realization of online intelligent teacher-comment system (shorted with system hereinafter) detailedly. The system is developed with C#.net in Visual 2003, the data
3、base used SQL Server 2000. The intelligence of system is mainly embodying in intelligent design comment items dynamically、creating the teacher-comment interface dynamically、setting illegal teacher-comment result characteristic intelligently、 Draw the list of teacher who teaches commented according t
4、o students number intelligently、to process intelligent analysis with the result(particularly to the different treatment with legal and illegal result) 、statistic the lists of not parting the teacher-comment intelligently after the teacher-comment、To commenting teacher according to the teacher-commen
5、t results and so on. Server operating system use 2003 Windows Server, it counts to be 500-2000 records database simultaneously per second. The system has higher stability and better maintenance level.【Keyword 】 Teaching assess, Assessment of intelligent teaching, dealt with illegally, intelligence g
6、rades2 绪论1.1 关于教评所谓教评,就是在教学的过程中,通过学生在学习过程中的反馈信息,对教师的授课情况的一项调查,目的是为了及时的了解教师与学生之间在教与学的过程中所遇到的问题,有针对性的开展教学工作,提高教学质量。教育理论与教育实践如何统一是当前教育界亟待解决的问题。教育评价标准系统是教育理论和教育实践的中间环节,教育评价有助于教育理论与教育实践达到统一。1.2 国内外关于教评的研究及系统所实现的目标1.2.1 目前国内外的研究,主要集中在以下几个方面: 教评的主体,学生教评是否科学关于教评是大多数教学工作者都认可的一种提高教学质量的有效手段,但是由谁来评,怎样来评,说法不一。有很
7、多人认为学生教评总体而言是最可靠、最公正的,基本上不受各种人际关系的影响。关键是要排除,有些教师故意迎合学生的心理,以获得较高的教评等级,可以与领导教评,教师之间教评相结合的方法来避免。教评应该从哪些方面进行评价教评可以从教学内容、教学态度、教学方法、教学效果等方面来进行评价。1.2.2 系统所实现的目标目前,网上已经有一些类似的教评系统,通过对这些系统的观察以及对使用过这些系统的老师和同学们的了解,我们发现:这些系统只是简单的将评价内容以网页的形式展现出来,让同学们选择,然后将结果统一的保存提交到服务器。这样做有很大的弊端,教评内容难于更新;教评结果的可信度有待提高;同时有多个用户登录时,系
8、统的运行状况不好等诸多问题。针对上述这些问题,我们的智能教评系统将得到很好的解决:通过读取数据库的内容,按管理员的要求,智能生成教评内容,可以随着数据库内容的不同随时更新,甚至可以做到不同的学科,有不同的教评内容;系统智能的判断出其中非法的评价结果(如:所有选项类同或具有某种规律性,这些都可以由管理员指定)进行区别处理,提高教评结果的可信度;对每个参与教评的学生,只记录教评提交的结果,并不与学号相对应,做到保密;3智能列出所登录的学生的任课教师,确保每个学生只允许对自己的任课教师进行教评,而且对每个教师只能评一次,提高教评结果的可信度;限制同时登录的用户的上限,或让所有用户分批登录,减轻服务器
9、的压力,保证系统运行安全平稳。教评结束后智能统计出没有参与教评的学生,依据教评结果对被评的教师打分,智能总结出优点和不足。1.3 系统的实现工具及开发环境系统主要使用 C#语言来开发,C#语言的开发工具目前主要是微软的Microsoft Visual Studio.NET,该工具包含了.NET 开发的各种语言。Visual Studio.NET 从一开始就是为 XML Web 服务创建的开发环境。通过允许应用程序通过 Internet 沟通和共享数据,允许开发人员从新的和现有的代码汇编应用程序,而与平台、编程语言或对象模型无关。数据库的访问,使用微软.NET 框架中的一种最新的数据访问技术AD
10、O.NET 来连接 SQL 数据库,整个数据库的配置运行均在 Sql Server 2000 中来完成。2 系统需求分析2.1 需求概述对于本系统来说,主要包括三类用户的需求:管理员需求,系统可以指定教评的对象,即学生信息;可以指定被教评的对象,即教师信息;指定教评的内容,即学生通过哪些方面对教师进行评价;对教评结果的查看,即查看所有教师的教评结果。教师需求,在教评结束后,通过登录,查看自己的教评结果。学生需求,在教评活动开始后,登录系统,对自己的任课教师评价。2.2 系统设想通过需求概述,可以设想到,系统至少要提供对三种不同身份用户登录的验证。当管理员登录时,可以对学生信息表、教师信息表以及
11、教评表的修改、更新;可以对教评结果进行查询。学生登录,对教评表查询,做出某些判断,根据判断更新教评结果表,教师登录,查看教评结果表中对应自己的记录。2.3 系统配置对于设计完成的系统,必须根据实际情况进行配置,否则就会容易造成资源浪费或系统运行不正常。软件配置软件配置主要包括操作系统的选择和数据库的设计,对于我们的系统主要4考虑在实际使用过程中用户对系统的稳定性、数据库的容量,用户的维护水平来确定的。数据库的选择因为设计这个系统主要是供河南科技学院教务处使用,考虑到我们学院拥有教师 1000 多名,学生 15000 多人,数据库中需要存储相当多的记录,在教评高峰也会有很多的用户同时登录,为了保
12、证系统的稳定性和良好的可维护性,本系统采用 SQL Server 数据库。这样可以使每秒数据库并发数据访问记录数达到 500050000。另外,如果是一个规模比较小的学校,数据库可以选择使用 Access;如果规模比较大,就要选择 Oracle,当然并不是在任何情况下使用 Oracle 数据库都会最好,有时也会受到经费的限制,一定要根据实际情况做适中的选择。操作系统选择在选择操作系统的时候,也要从用户的数量和系统的吞吐量等方面来考虑,结合我们学院的具体情况,本系统使用 Windows Server 2003,这样会具有较好的维护水平。同样对于较小规模可以使用 Windows 2000,对于较大
13、规模的还可以使用Unix,这也要根据实际情况决定。硬件配置硬件配置主要包括服务器端和客户端硬件的选择。对于客户端没有太大的要求,一般的能够上网的机器都可以满足要求。对于服务器端较高的配置会使系统运行的更快,更安全。网络配置可以选择的类型有以下几种单机模式:服务器端和客户端在一台机器上百兆模式:计算机网络速度为百兆千兆模式:计算机网络速度为千兆网络连接如下图所示,对于不同的模式只不过所选用的交换机不同用户终端 1交换机服务器用户终端 25图 系统的网络配置模型图3 总体设计过程3.1 功能模块设计网上智能教学教评系统各类用户登录模块 学生信息管理模块 教师信息管理模块 教评信息管理模块 非法数据
14、设置模块 学生教评提交模块 教评结果查看模块图 2 系统主要功能模块各类用户登录模块:管理员登录,主要是对系统进行后台设置,具体包括对教师和学生的信息进行设置,对教评的项目进行设置,对非法数据特征进行设置,查看所有被评的教师的教评结果。学生登录,个人信息的修改,对自己的任课教师教评。教师登录,查看自己的教评结果以及学生的留言。学生信息管理模块:添加、删除、修改学生信息。教师信息管理模块:添加、删除、修改教师信息。教评信息管理模块:添加、删除、修改教评信息。非法数据设置模块:对教评结果中有可能出现的非法数据的特征进行设置。学生教评提交模块:对教师进行教评,并把结果提交到服务器的数据库中。教评结果
15、查看模块:查看所有的教师的教评结果。3.2 系统所需主要数据库设计在这里给出了一些主要的数据库的建立语句,通过执行,可以很容易的生成系统所需要的数据库。教评类别表 pjItem 包括的字段: 教评编号(pjNum) 、教评类别(pj )CREATE TABLE pjItem (pjNum varchar (2) COLLATE Chinese_PRC_CI_AS NOT NULL ,6pj varchar (20) COLLATE Chinese_PRC_CI_AS NOT NULL ,PRIMARY KEY CLUSTERED (pjNum) ON PRIMARY ) ON PRIMARYG
16、O教评项目表 pjDet 包括的字段:教评编号(pjNum ) 、教评内容(pjItem) 、教评选项(pj1-4)、教评所属类别 (pjf)CREATE TABLE pjDet (pjNum varchar (2) COLLATE Chinese_PRC_CI_AS NOT NULL ,pjItem varchar (100) COLLATE Chinese_PRC_CI_AS NOT NULL ,pj1 varchar (20) COLLATE Chinese_PRC_CI_AS NULL ,pj2 varchar (20) COLLATE Chinese_PRC_CI_AS NULL ,
17、pj3 varchar (20) COLLATE Chinese_PRC_CI_AS NULL ,pj4 varchar (20) COLLATE Chinese_PRC_CI_AS NULL ,pjf varchar (10) COLLATE Chinese_PRC_CI_AS NOT NULL ,CONSTRAINT PK_pjDet_00551192 PRIMARY KEY CLUSTERED ( pjNum ) ON PRIMARY ) ON PRIMARYGO智能判断非法数据表 pd 包括字段:判断项(pdItem)CREATE TABLE pd ( pdItem varchar (
18、50) COLLATE Chinese_PRC_CI_AS NULL ) ON PRIMARYGO智能统计出没有参与教评的学生名单 flag 学号(stuNum) 、教师编号(teaNum) 、标志(flag)CREATE TABLE flag (stuNum varchar (8) COLLATE Chinese_PRC_CI_AS NULL ,teaNum varchar (4) COLLATE Chinese_PRC_CI_AS NULL ,flag varchar (2) COLLATE Chinese_PRC_CI_AS NULL ) ON PRIMARYGO4 详细设计4.1 页面
19、设计流程图通过上述的需求分析和总体设计,我们已经大致了解了整个教评系统的流程,基本上可以概括为,管理员登录,对系统做具体设置,包括设置哪些人参与教评,通过哪些标准来教评,用这些标准对谁教评;接下来,参与教评的人对被教评的人依据教评标准教评;管理员查看所有的教评结果;被教评人查看自己的教评结果。这些只是给出了系统的大致流程,而要真正的实现这个系统,解决我们所列出的问题,还需要很多附加的设置与操作。7下面我们给出了整个系统较为详细的页面流程图,在详细设计过程中,我们将逐步地给予详细的介绍,对实现智能性方面做重点介绍:8否否是否是非法系统登录判断用户类型 test学生 管理员 教师Test 数据库包
20、含学生表、教师表、管理员表等列出任课教师注销StuTeapjDetpjItempd确定更改提交教评结果生成教评界面是否合法是否评完AB退出登录Flag查看结果按编号筛选是图 3 页面流程设计图 图中数据库说明Stu 学生信息表Tea 教师信息表pjItem 教评类别表pjDet 教评项目表pd 教评判断表A 合法结果表B 非法结果表Flag 教评标志表94.2 系统功能分析与代码实现 根据系统的主要功能模块和页面流程的设计,我们可以得出系统所具备的功能:其中最基本的功能是:管理员登录,根据实际情况添加教师和学生的信息,添加或修改教评内容,开启教评系统,允许学生登录开始教评;学生登录系统,根据教
21、师上课的实际情况和所列出的教评内容,对自己的任课教师进行教评,系统对结果进行保存提交;教师登录,当教评过程结束后,可以查看学生对自己的教评结果,从中找出自己的优点和不足。智能完善的功能:根据管理员对教评库的设置,智能生成教评界面,使教评项目更新方便;根据学生的学号不同,自动列出对应的教师;点击对教师教评,甚至可以按照管理员的意愿,不同的学科,可以给出不同的评价内容;根据管理员的设置,智能生成非法数据特征库,作为评价提交结果是否合法的依据;对于非法的评价结果进行智能筛选,区别处理;智能统计出没有参与教评的学生名单;根据教评结果,对每个教师得出结论或者依据评分规则进行打分。4.3 各模块具体的设计
22、类是面向对象语言中很有特色的一种程序设计思想。在这里,我们正是通过一个名字为 DB 的类,来完成对 SQL 数据库的连接,它包含在系统的 DB.cs页面中,具体实现代码为:using System;using System.Data .SqlClient ;namespace pjtest / / DB 的摘要说明。/ public class DB public DB()/ TODO: 在此处添加构造函数逻辑 public static SqlConnection createCon() SqlConnection con=new SqlConnection (“server=.;datab
23、ase=test;uid=sa;pwd=sa“);10return con;/.代表本地主机;test 为数据库名; sa 为用户名和密码4.3.1 各类用户登录模块此模块设计起来相对简单,是整个系统进入时第一个呈现给用户的页面,系统中命名为 Index.aspx,系统使用下拉列表框控件来对三种不同的身份的用户的选择,然后用两个文本框分别接收用户输入的用户名和密码,通过一个登录按钮对输入进行确认并提交到服务器。图系统登录界面截图系统根据选择用户的不同,到相应的数据库中进行检索,验证正在登录的用户的身份是否合法,具体的实现,是通过的 Select 语句,把用户名和密码设置为要查询的条件,在数据库
24、中执行,如果相应的数据库中有这一条记录,则认为此用户存在,被认为是合法的用户;对于合法的用户,根据用户类型的不同,跳转到不同的页面;对于非法的用户给出错误提示,要求重新输入,直到输入正确的信息才可以登录。该模块设计的关键保证合法用户正常登录,非法用户即使通过正确的地址也不能跳转,这主要是通过 Session 变量来判断,以保证系统的安全性。4.3.2 学生信息管理模块此模块的设计主要是对学生数据库的修改,该模块在系统中是通过mainStu.aspx 页面来实现,页面中使用 DataGrid 控件和数据库中的学生信息表11进行绑定,对其中记录的修改都将影响到学生数据库。包括对学生信息的添加、删除
25、、修改等操作。添加学生的主要代码:private void btnADD_Click(object sender, System.EventArgs e)/此代码为学生信息管理页面的添加学生的单击事件try/使用 try 语句,主要对于异常的处理SqlConnection con=DB.createCon ();/建立数据库连接string stuNum=this.txtNum.Text ;string stuName=this.txtName.Text ;string stuClass=this.txtClass.Text ;string stuPwd=this.txtPwd .Text ;
26、if (stuNum=“) Response.Write (“ 学号不能为空“);/ 对错误的一般判断 else/记录的插入语句SqlCommand cmd=new SqlCommand (“insert into stu values(“+stuNum+“,“+stuName+“,“+stuClass+“,“+stuPwd+“)“,con);con.Open();cmd.ExecuteNonQuery ();/执行数据库语句this.BindToDataGrid ();/对数据库向 datagrid 的绑定con.Close ();Response.Write (“添加学生成功“); cat
27、chResponse.Write (“添加失败,请检查约束项!“); 12图学生信息管理模块截图4.3.3 教师信息管理模块实现方式与学生信息管理模块相同,在系统中为 mainTea.aspx 页面。图教师信息管理模块截图对教师库的更新语句private void dgTea_UpdateCommand13(object source, System.Web.UI.WebControls.DataGridCommandEventArgs e) string teaNum=this.dgTea .DataKeys e.Item .ItemIndex .Toting ();string teaNa
28、me= (TextBox)(e.Item .Cells 1.Controls 0).Text ;string teaPwd= (TextBox)(e.Item .Cells 2.Controls 0).Text ;string teaItem= (TextBox)(e.Item .Cells 3.Controls 0).Text ;string teaClass=(TextBox)(e.Item .Cells 4.Controls 0).Text ;SqlConnection con=DB.createCon ();SqlCommand cmd=new SqlCommand (“update
29、tea set teaName=“+teaName+“,teaPwd=“+teaPwd+“,teaItem=“+teaItem+“,teaClass=“+teaClass+“where teaNum=“+teaNum+“,con);/数据库更新语句con.Open();cmd.ExecuteNonQuery (); this.BindToDataGrid ();con.Close (); /语句结束4.3.4 教评信息管理模块此模块为整个系统比较核心的模块,该模块只能由系统管理员来操作,通过该模块系统管理员可以很方便的设置教评选项,生成教评页面;对于已经生成的评选项目,还可以即时的修改,形成新
30、的教评页面。下面将重点介绍该模块的实现过程:图教评信息管理模块截图对于数据库中插入语句的删除private void dgpjItem _DeleteCommand(object source, System.Web.UI.WebControls.DataGridCommandEventArgs e)14 string pjNum=this.dgpjItem .DataKeys e.Item .ItemIndex .ToString ();SqlConnection con=DB.createCon ();SqlCommand cmd= new SqlCommand (“delete from
31、 pjItem where pjNum=“+pjNum+“,con);con.Open ();cmd.ExecuteNonQuery ();this.BindToDataGrid (); con.Close();this.BindToddlNum (); private void BindToddlNum() /自定义函数 SqlConnection con=DB.createCon ();con.Open ();SqlCommand cmd=new SqlCommand (“select * from pjItem“,con);SqlDataReader sdr=cmd.ExecuteRea
32、der ();this.ddlNum .DataSource =sdr;this.ddlNum .DataTextField =“pj“;this.ddlNum .DataValueField =“pjNum“;this.ddlNum .DataBind ();sdr.Close (); con.Close ();是教评项目库教评类别库管理员登录验证身份Admin进入教评项目管理退出系统否pjItempjDet更改教评库读取库,形成新的教评界面管理员库注销管理员15图 教评信息管理模块的具体实现流程图根据上面的流程图,我们从中分析:首先要判断登录的是否为合法的管理员,通过查询数据库判断的方法,
33、前面已经说过,这里不再多说;主要是验证是否通过正确的途径跳转到本页面。在我们这个系统中,所有的跳转判断都是通过 juge.aspx 来实现,在 juge.aspx 的 Page_Load 事件中添加以下的代码:If ( Session“flag“=null ) Response.Redirect (“loginFail.aspx“); 然后,在各个页面中只需要调用就可以了。进入该页面后,系统首先通过两个 datagrid 分别与评选类别表( pjDet) 、评选项目表(pjItem)的绑定列出来;在 datagrid 中通过模板可以直接实现修改和删除的功能,由于表中的记录有可能过多,这里要考虑
34、实现分页;在 datagrid中实现添加的功能比较复杂,这里我们采用一种比较简单的方法,在页面上添加文本框,通过文本框的输入来添加到数据库中,这里还是使用语句来实现的,当点击“确定”按钮后,更改将直接影响到数据库中的记录,在更改以后,教评界面将根据数据库的记录的不同重新生成,这样的设计可以使系统维护更加简单,大部分的工作都可以让系统智能处理,即使一点都不懂计算机语言的用户,也可以很容易生成新的教评页面。4.3.5 非法数据设置模块此模块为整个系统实现智能性的核心,它的设计原理类似于杀毒软件中的病毒库;当计算机中存在某些文件,它的运行的特征,在杀毒软件的病毒库中被认为是病毒,则就会把该文件视为病
35、毒来处理;而在我们的系统中也是这样的,下面我们将详细介绍一下该模块的实现过程:图非法数据设置模块截图16在管理员登录该模块后,展现给用户的是一组由复选框组成的设置界面,在系统中为用户提供了一些常用的设置非法的选项,比如全部选择第一项、第二项、第三项、第四项以及选择的项目包含某种顺序规律都可以在这里指定。这里,我们假设管理员想要设置全部选择 B、全部选择 C 以及全部选择 D是不可信的教评数据,则管理员登录后,可以选中第二项、第三项、以及第四项,然后点击页面上的“提交”按钮,接下来系统先与判断表相连接,再开始从第一个复选框开始判断是否被选中,执行相应的操作;当判断第二项被选中后,系统将生成一个全
36、为“B” 的字符串,长度为教评项目表中项目的个数,然后再将该字符串插入到判断表中,接下来再判断下一个复选框是否被选中,如果被选中则会执行与前面相类似的操作;直到把所有的复选框判断完。这样即可按照管理员的意愿完成对非法数据模型的设置。当管理员选中某种顺序规律时,系统会组成一些常见的有顺序的选项排列,如 ABCDAD ABCAC BCDBD 等除此之外,为了使系统使用起来更加灵活,更大程度上的提高系统的智能性,系统还增加了用户自定义的功能,即用户可以自己设置一些除系统所列之外但也被认为是非法或不可信的模型,当选中了页面上的自定义复选框后,页面上会显示出一个文本框,在文本框里面用户可以填写非法模型。
37、为了方便用户使用,这里并不需要用户把整个非法排列都写出来,而是只给出局部的排列,当点击“添加”按钮后系统自动的把它循环生成相应的字符串,然后在列表框中列出来,同时把文本框清空,可以继续添加第二个自定义;同理,可以把所有你认为非法的模型都添加进来,最后整体的提交到数据库中。举例:如果你自定义添加了“AB”,则会生成“ABABAB”的字符串,并插入到数据库中。这里字符串的长度用户不需要考虑,完全由系统根据评选项目的个数自动生成。4.3.6 用户教评提交模块此模块为学生登录后,再选择自己的任课教师,然后展现给学生的页面,在系统中命名为 mainPj.aspx,该模块为整个系统的核心模块,也是被浏览次
38、数最多的页面,其它的所有模块的设计都是为该模块服务的,都要靠该模块来实现,所以这个模块设计的好坏,将直接影响到整个教评系统运行的好坏。以下代码为对教评界面的优化:Private void clear () /去掉datagrid 中前面相同的列 string pjNum=this.dgMainPj .Items 0.Cells 0.Text ;string pj=this.dgMainPj .Items 0.Cells 1.Text ;for(int i=1;ithis.dgMainPj .Items .Count ;i+)17if(pjNum=this.dgMainPj .Items i.C
39、ells0.Text )this.dgMainPj .Items i.Cells 0.Text =“;this.dgMainPj .Items i.Cells 1.Text =“;elsepjNum=this.dgMainPj .Items i.Cells 0.Text ;pj=this.dgMainPj .Items i.Cells 1.Text ;在用户进入该模块后,首选系统将检索数据库中的教评类别表和教评项目表,并按照类别将教评项目以表格的形式列出来;对于教评项目中的选项,将在选项的前面添加单选按钮,用来供用户选择。系统对教评类别和教评项目没有任何的限制,完全可以由管理员按照实际情况或自
40、己的意愿来设置,只要是按照正常的方式添加的,都可以很好的生成美观的教评页面。 (在这里,我们需要说明一点,如果还想增加系统的智能性,使系统更为合理。我们还可以在点击开始教评后,记录下来被教评的教师编号和课程编号,根据教师所属系的不同和所教课程的不同,连接不同的教评类别表和教评项目表,以便做到对不同学科的教师进行不同标准的教评,这样可以使得教评更为合理,教评结果更为真实可靠。 )以下代码为实现学生教评结果的判断并向数据库提交:private void btnTj_Click(object sender, System.EventArgs e)int a=0;string b=“;bool fla
41、g=true;for (int i=0;ithis.dgMainPj .Items .Count ;i+) for (int j=1;j=4;j+) if(RadioButton)(this.dgMainPj .Items i.Cells 2+j.Controls 1).Checked )a=j; break ; if(a=0) flag=false;b=b+a.ToString ();a=0;if(!flag)18Response. Write (“其中包含没有选择的项目!请检查,确保每一项都选择“);/产生教评结果,存在于字符串b中;string teaNum=Request.QueryS
42、tring “teaNum“.ToString ();/接受传递过来的教师编号string str;SqlConnection con=DB.createCon ();SqlCommand cmd=new SqlCommand (“select count(*) from pd where pdItem=“ +b+ “ ,con );con.Open(); / 打开数据库连接int count=Convert.ToInt32 (cmd.ExecuteScalar ();con.Close ();if(count=0)cmd.CommandText =“insert into resultA v
43、alues (“+teaNum+“,“+b+“)“ ;str=“你对该教师评选的结果,提交成功!“;elsecmd.CommandText =“insert into resultB values (“+teaNum+“,“+b+“)“ ;str=“由于您所评的结果,被管理员认为是非法的,但还是被提交,请珍惜你的权力!“; con.Open ();cmd.ExecuteNonQuery ();/执行数据库操作Response.Write (str);con.Close (); /关闭数据库连接string stuNum=Session“stuNum“.ToString ();cmd.Comma
44、ndText =“update flag set flag=1where stuNum=“+stuNum+“and teaNum=“+teaNum+“;con.Open ();cmd.ExecuteNonQuery ();con.Close ();this.LinkButton1.Visible =true; /显示返回按钮this.btnTj .Enabled =false; /提交按钮不可用19图 10 教评系统主界面截图当用户对教评项目选择完成后,点击提交按钮后,系统将准备把用户的选择结果保存到数据库中。在保存期间,系统首选会判断一下,是否每一个教评项目用户都做出了选择,对于没有完成所有
45、选择的情况,系统将给出智能提示,让用户做出选择。直至所有的选项用户都做出了选择。然后,系统将把用户选择的结果与非法结果特征库相比较,以此来判断用户的选择是否可信。对于可信的结果,将给出提示,并写入合法结果数据库中,即 resultA 中;而对于不可信的结果,也将给出提示,告知用户要做出正确的选择,并写入非法的数据库中,即 resultB 中。对于可信的和不可信的教评结果系统都允许提交到数据库中,只不过所给的提示和所写入的数据库有所不同。当然也可以改为,对于不可信的教评结果不允许提交,只需对代码稍加更改即可以实现,在这里不再多说了。向数据库提交结果时,系统只将教师编号,课程编号,教评的结果这三项
46、进行提交,而不把学生的学号提交,这样做是为了增加教评的可信度,从根本上杜绝每个学生的教评结果被泄漏。当结果提交成功后,页面上将显现出一个“返回”按钮,点击该按钮系统将回到选择教师开始教评的界面。在这里我们会发现系统非常智能,当一个学生对自己其中的一个任课教师完成教评回到这个界面后,系统将把已经评过教的教师隐藏起来,只把那些还没有评的教师列出来,非常方便学生的使用。这一点的实现技巧也很简单,只是在系统中增加了一个标志数据库,标志数据库是系统根据学生库和教师库的记录自动生成的,无需管理员的任何操作,随便20学生库和教师库的不同,标志库也会自动的变化,随时满足系统的需要。在标志数据库中,只有学生编号
47、,教师编号以及一个标志位,每一个学生编号都将对应他所有的任课教师的编号。在系统初始化的时候,所有的标志位都为 0,每当一个学生对自己的某个任课教师完成教评后,对应的标志位就会改为 1,用来标志此学生已经对该教师进行了教评。有了标志数据库的存在,在学生通过学号和密码登录到系统后,系统将会检索标志数据库,从中找出所有学号与登录学号相同的记录,并把其中标志位为 0 的记录列出来,当对一个教师完成教评后,点击“返回”按钮后,系统将重新执行上面的操作。由于标志位的变化,相应的被教评的教师列表也会发生适时的变化。另外,根据标志数据库,在教评活动结束后,系统也可以很轻松的列出没有按要求参与并完成教评的学生,
48、方便管理员了解参与教评活动的学生的具体情况,更好的利用教评结果。对标志数据库的说明:随着教师和学生的人数的增多,标志数据库的记录会成倍的增长。在对数据库的检索的性能,可能会有所下将,但对系统整体性能的影响是微乎其微的。由于标志数据库的存在,可以很好的解决智能列出每个学生对应的教师、适时显示每个学生还未完成教评的教师,智能统计没有参与教评的学生名单等一系列的问题,所以它的存在还是很有意义的。4.3.7 教评结果查看模块本系统提供了两种不同方式的查询,管理员可以在教评的整个过程中,对所有教师的教评结果进行查询,实时掌握教评活动的最新进展,方便控制整个活动的进度;教师可以在整个教评活动结束后,查询教评的结果,但是只可以查看学生对自己的教评结果,不可以查看别的教师的教评结果。21图 11 教评结果查看截图5 结论本文用较为详细的文字,介绍了网上智能教评系统的设计与实现。系统除了具有普遍意义上的网上教评功能外,重点在系统的智能性、灵活性、提高教评结果的可信度等方面进行了深入的研究,取得了一定的成果。但是系统刚刚开发成功,还需要相当长时间的运行测试,系统的智能性还有待于进一步提高。6 参考文献1 Daniel Cazzulino 等箸 王晓娜 译C# W