在线考试系统课程设计.docx

上传人:牧羊曲112 文档编号:3380716 上传时间:2023-03-12 格式:DOCX 页数:20 大小:42.88KB
返回 下载 相关 举报
在线考试系统课程设计.docx_第1页
第1页 / 共20页
在线考试系统课程设计.docx_第2页
第2页 / 共20页
在线考试系统课程设计.docx_第3页
第3页 / 共20页
在线考试系统课程设计.docx_第4页
第4页 / 共20页
在线考试系统课程设计.docx_第5页
第5页 / 共20页
亲,该文档总共20页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

《在线考试系统课程设计.docx》由会员分享,可在线阅读,更多相关《在线考试系统课程设计.docx(20页珍藏版)》请在三一办公上搜索。

1、在线考试系统课程设计一、需求分析 计算机技术没有应用到考试上时,组织一次考试只是要经过五步:人工出题,考生考试,人工阅卷,成绩评估和试卷分析,这是一项十分繁琐和容易出错的工作,教师的工作量非常的大。很明显,传统的考试方式已经不再适应现代考试的需要。如今,信息技术的迅猛发展,应用不断扩大,教学和虚拟大学等相继出现,这些应用正逐步深入到千家万户,人们迫切要求利用这些技术来进行在线考试,以减少教师的工作负担并提高工作效率,同时提高考试的质量,从而使考试更趋于公正,客观,更加激发学生的兴趣。例如,目前许多国际著名的计算机公司所举办的各种认证考试绝大部分是采用这种形式。 二、数据库设计 1, 概念模型设

2、计 用户类型用户账号 用户密码 用户信息 是否参加了考试 是否已经登录 用户姓名 试题类型 试题编号 试题答案 试题题目 选项 A 选项B 试题题库 选项F 选项E 选项C 选项D 参数编号 考试时间 系统参数 试卷类型 题库中的编号 题目在试卷中的编号 题目答案 学生考试试卷 考生答案 选项A 选项B 选项C 选项D 选项E 选项F 考生编号 考生成绩 学生成绩 选择题成绩 判断题成绩 填空题成绩 2、E-R图转为逻辑模型的方法及过程 在sql中创建一个新的数据库CET6,以ER图中的实体的名称创建表。设计表时,以该ER图中的属性为列名,根据实际情况确定其数据类型和长度,在必须唯一的列名处设

3、计主键。在sql中一共建立七个表来实现CET6模拟考试系统应用程序数据的连接。其中,UserType表示数据类型,0表示学生,1表示管理员。UserId表示用户账号,UserName表示用户姓名,UserPsw表示用户密码。HaveIn,HaveTest分别表示用户是否登录和参加考试。TypeId,TypeName分别表示试题类型和试题类型名。XZT_BL,XZT_FZ分别表示选择题的分值和比例。判断题和填空题类推。StudentId表示考生考号,TopicId、PaperTopId分别表示试题在题库和试卷中的编号。TopicName、TopicAnswer表示试题题目和答案。 3、逻辑模型

4、TB_User TB_TestType TB_Param(系统参数表) TB_StuTest(学生考试试卷表) TB_Grade(学生分数表) TB_Test(试题安排) TB_StuTest(学生考试试卷表) 4、数据库评价 首先,用sql设计数据库比较稳定,对数据的要求也比较严格。这样在编码阶段数据这一块就基本没有不合理的数据出现在应用程序上。减少了运行会出现的错误。但是sql与应用程序的链接有时比较繁琐而且不易成功。 三、编码实现 1, 登录模块 1) 用户的不同类型进入到不同的界面,主要有一个combox控件,用于选择用户类型。两个TextBox控件,Txt_id用于输入账号,Txt_

5、Pse用于输入密码。三个commandButton控件:cmd_In用于登录系统,Cmd_Again用于清空用户信息重新输入,Cmd_Quit用于退出系统。 程序流程图 登录 学生 输入用户名密码 2) 管理员 输入用户类型 输入用户名密码 错误 错误 进入学生界面 进入管理员界面 结束登录 3) 登录模块代码 Option Explicit Public B As Boolean 用户的登录信息是否正确 Private Sub PD判断用户登录信息是否正确,正确B=true,否则B=false Dim rs As New ADODB.Recordset 声明rs为记录集对象 If Trim(

6、Txt_Id.Text) = Then 如果没有输入帐号 MsgBox 没有输入用户账号,请您正确填写!, vbOKCancel + vbCritical Txt_Id.SetFocus 设置焦点在问本框Txt_Id上 ElseIf Trim(Txt_Psw.Text) = Then 如果密码为空 MsgBox 没有输入密码,请您正确填写!, vbOKCancel + vbCritical Txt_Psw.SetFocus 设置焦点在问本框Txt_Psw上 Else Cmd_In.Default = True 设置Cmd_In按Enter键触发Click事件 Sql = select * fr

7、om TB_User where UserId= & Trim(Txt_Id.Text) & & _and UserType= & Cbx_UserType.ListIndex & & _and UserPsw= & Trim(Txt_Psw.Text) & 把查询用户信息的SQL语句赋给变量Sql rs.Open Sql, cnn, adOpenStatic, adLockReadOnly 以只读的方式静态的打开Sql执行的结果的记录集 If Not rs.RecordCount 0 Then 如果记录集为空 Select Case MsgBox(用户账号或密码不正确,请您正确填写!, vb

8、OKCancel + vbCritical) 显示提示信息 Case vbOK 如果选择了是 B = False Txt_Id.Text = 帐号清空 Txt_Psw.Text = 密码清空 Txt_Id.SetFocus 是输入帐号的文本框获得焦点 Case Else 选择了取消 End 结束程序 End Select Cmd_In.Default = False 设置Cmd_In不是Enter的默认按钮 ElseIf rs.Fields(HaveIn) = 0 Then 如果记录集不为空且此帐号没被其他用户使用 B = True 用户的登录信息正确 cnn.Execute update T

9、B_User set HaveIn=1 & _where UserId= & Trim(Txt_Id.Text) & & _and UserType= & Cbx_UserType.ListIndex & 设置HaveIn字段为1,限制其他用户用此帐户登录 UsId = Trim(Txt_Id.Text) 记录用户的帐号 Else 如果记录集不为空但此帐号正在被其他用户使用 MsgBox 用户已经登录!, vbOKOnly + vbCritical 显示提示信息 B = False 用户的登录信息错误 Txt_Id.Text = 帐号清空 Txt_Psw.Text = 密码清空 Txt_Id.

10、SetFocus 是输入帐号的文本框获得焦点 Cmd_In.Default = False 设置Cmd_In不是Enter的默认按钮 End If rs.Close 关闭记录集 End If End Sub Private Sub Cbx_UserType_KeyPress(KeyAscii As Integer) If KeyAscii = 13 Then 如果输入的字符是Enter键 Txt_Id.SetFocus 设置输入帐号的文本框获得焦点 Else 如果输入的是其它字符 KeyAscii = 0 返回值为空即不输入任何字符 End If End Sub Private Sub Cmd

11、_Again_Click 用户信息输入错误,选择了“重输”按钮,开始重新输入。 Call Form_Load End Sub Private Sub Cmd_In_Click 用户填写信息完毕,单击“确定”按钮,开始登录 On Error GoTo Err1 出现错误转向错误处理 Dim rs As New ADODB.Recordset 声明rs为记录集对象 Select Case Cbx_UserType.ListIndex Select语句的条件是Cbx_UserType的ListIndex属性 Case 0 如果选中的是第一条记录即考生 Call PD 判断考生的帐号和密码是否正确 I

12、f B = True Then 如果考生的帐号和密码正确 Sql = select HaveTest from TB_User where UserType=0 & _ and UserId= & Trim(Txt_Id.Text) & 判断考生是否参加过考试 rs.Open Sql, cnn, adOpenStatic, adLockReadOnly 执行SQL语句 If rs.Fields(HaveTest) = False Then 如果考生没有参加过考试 Sql = delete from TB_Grade where StuId= & _ & Trim(Txt_Id.Text) &

13、删除成绩表中考生原有的记录 cnn.Execute Sql 执行SQL语句 Sql = insert into TB_Grade(StuId) values & _ ( & Trim(Txt_Id.Text) & ) 把考生的帐号插入到成绩表中 cnn.Execute Sql 执行SQL语句 End If frm_Stu.Show 显示考生窗口 Unload Me 卸载本窗体 End If Case 1 If Txt_Id.Text = admin And Txt_Psw = admin Then 设置超级用户 Unload Me 卸载本窗体 frm_Manager.Show 显示管理员窗体

14、Else 如果不是超级用户 Call PD 判断管理员的帐号和密码是否正确 If B = True Then 如果帐号和密码正确 Unload Me 卸载本窗体 frm_Manager.Show 显示管理员窗体 End If End If Case Else 不过没有选择用户的身份 MsgBox 您没有选择身份,请选择!, vbOKCancel + vbCritical 提示选择身份 Cbx_UserType.SetFocus 组合框Cbx_UserType获得焦点 End Select Exit Sub 跳出Sub过程 Err1: ErrMessageBox 打开窗口失败 显示出错信息 fr

15、m_Login.Show 显示登录窗体 End Sub Private Sub Cmd_Quit_Click If MsgBox(真的要退出 & Me.Caption & 吗?, vbYesNo + vbInformation) = vbNo Then Exit Sub End If 弹出对话框询问是否退出系统 End 退出系统 End Sub Private Sub Form_Load Cbx_UserType.Text = 请选择身份 Txt_Id.Text = Txt_Psw.Text = End Sub Private Sub Txt_Id_KeyPress(KeyAscii As I

16、nteger) If KeyAscii = 13 Then 判断如果用户输入的是Enter键 Txt_Psw.SetFocus 设置Txt_Psw获得焦点 End If End Sub Private Sub Txt_Psw_KeyPress(KeyAscii As Integer) If KeyAscii = 13 Then Call Cmd_In_Click End If End Sub 2、管理员模块 1)在窗体上添加一个SSTab控件,上面添加三个commandButton控件,分别为选择题,填空题,判断题。添加一个DataGrid控件显示试题,添加一个Ado控件链接数据库。编写菜单实

17、现各种管理的功能。 2) 管理员 用户管理 修改系统系数 题库维护 查询考生成绩 结束程序 3) 代码 Option Explicit Dim Sql As String 声明模块级变量 Private Declare Function ShellExecute Lib shell32.dll Alias ShellExecuteA (ByVal hwnd As Long, ByVal lpOperation As String, ByVal lpFile As String, ByVal lpParameters As Long, ByVal lpDirectory As Long, ByV

18、al nShowCmd As Long) As Long Private Function FunAdo(ByVal str As String) 构造连接ADO的函数 On Error GoTo Err1 执行过程中如果发生错误转向错误处理 With Ado1 使用With结构 .Visible = False Ado不可见 .ConnectionString = cnn.ConnectionString 设置Ado的连接字符串 .CommandType = adCmdText 设置Ado的命令类型 .RecordSource = str 设置Ado的记录源 .Refresh 刷新Ado的记

19、录集 End With 结束With结构 Exit Function 结束函数 Err1: ErrMessageBox 与数据库连接失败! 显示错误信息 Me.Show 显示窗口 End Function Private Sub Cmd_Cancel_Click Call Form_Unload(1) End Sub Private Sub Cmd_PDT_Click Sql = select 类型号=tb_testtype.Typeid,题号=(tb_topicstor.topicid), & _ 题目名称=topicname,答案=topicanswer & _ from tb_topic

20、stor,tb_testtype where tb_testtype.typeid=tb_topicstor.typeid and typename=判断题 Call FunAdo(Sql) DG.Columns(0).Width = 700 DG.Columns(1).Width = 500 DG.Columns(2).Width = 4000 DG.Columns(3).Width = 500 End Sub Private Sub Cmd_TKT_Click Sql = select 类型号=tb_testtype.Typeid,题号=(tb_topicstor.topicid), &

21、_ 题目名称=topicname,答案=topicanswer & _ from tb_topicstor,tb_testtype where tb_testtype.typeid=tb_topicstor.typeid and typename=填空题 Call FunAdo(Sql) DG.Columns(0).Width = 700 DG.Columns(1).Width = 500 DG.Columns(2).Width = 4000 End Sub Private Sub Cmd_XZT_Click Sql = select 类型号=tb_testtype.Typeid,题号=(tb

22、_topicstor.topicid), & _ 题目名称=topicname,答案=topicanswer,A,B,C,D,E,F & _ from tb_topicstor,tb_testtype where tb_testtype.typeid=tb_topicstor.typeid & _ and typename= & Cmd_XZT.Caption & 把查看选择题的SQL语句赋给变量Sql Call FunAdo(Sql) 调用函数执行SQL语句 DG.Columns(0).Width = 700 设置DataGrid的第1列列宽 DG.Columns(1).Width = 50

23、0 设置DataGrid的第2列列宽 DG.Columns(2).Width = 4000 设置DataGrid的第3列列宽 DG.Columns(3).Width = 500 设置DataGrid的第4列列宽 End Sub Private Sub DG_DblClick If frm_Manager.Ado1.Recordset.Fields(题号) = Then 如果试题不存在 MsgBox 不存在记录,请您先添加记录, vbOKOnly 提示没有记录 Exit Sub 跳出Sub过程 Else 如果题库中有试题 Me.Enabled = False 管理窗体不可以用 Bkm = Ado

24、1.Recordset.Bookmark 记录当前DataGrid的指针的位置 End If End Sub Private Sub Form_Load Call Cmd_XZT_Click End Sub Private Sub Form_Unload(Cancel As Integer) If MsgBox(真的要退出 & Me.Caption & 吗?, vbYesNo + vbInformation) = vbNo Then 弹出消息对话框询问是否退出系统 Cancel = True 如果消息对话框返回值为常数vbNo,系统返回值为True Else cnn.Execute updat

25、e tb_user set havein=0 where userid= & UsId & and UserType=1 End 如果消息对话框返回值为常数vbNo,系统返回值为False,结束程序 End If End Sub Private Sub Men_About_Click frm_About.Show End Sub Private Sub Men_Help_Click SendKeys F1 End Sub Private Sub Men_SelGrd_Click frm_SelGrd.Show 打开查分窗体 Me.Hide 隐藏管理员窗体 End Sub Private Sub

26、 select_Click 设定参数 On Error GoTo Endsub frm_param.Show Me.Hide Endsub: End Sub PrivateSub T_AddPDT_Click On Error GoTo Endsub frm_PDT.Show Me.Hide Endsub: End Sub PrivateSub T_AddTKT_Click On Error GoTo Endsub frm_TKT.Show Me.Hide Endsub: End Sub Private Sub T_AddXZT_Click On Error GoTo Endsub frm_X

27、ZT.Show Me.Hide Endsub: End Sub Private Sub T_Exit_Click Unload Me End Sub Private Sub T_Update_Click On Error GoTo Endsub Me.Enabled = False Endsub: End Sub Private Sub User_Click On Error GoTo Endsub frm_UpdateUser.Show Me.Hide Endsub: End Sub 3、学生窗体 1) 2) 考生 是否已经参加考试 修改密码 开始考试 查询成绩 修改密码 退出系统 3) O

28、ption Explicit Dim HaveTest As Integer Private Sub Begin_Click Call CmdOk_Click End Sub Private Sub CmdOk_Click On Error GoTo Err1 frm_Test.Show Me.Hide Exit Sub Err1: ErrMessageBox 考试窗口打开出错 End Sub Private Sub CmdQuit_Click Unload Me End Sub Private Sub Form_Load Dim rs As New ADODB.Recordset 声明认识r

29、s为记录集对象 Sql = select havetest from tb_user where usertype=0 & _ and userid= & UsId & 把查询是否参加考试的标识字段赋给变量Sql rs.Open Sql, cnn, adOpenStatic, adLockReadOnly 执行SQL语句 HaveTest = rs.Fields(HaveTest) ShowButton End Sub Private Sub Form_Unload(Cancel As Integer) If MsgBox(真的要退出 & Me.Caption & 吗?, vbYesNo +

30、vbInformation) = vbNo Then 弹出对话框询问是否退出系统 Cancel = 1 Else cnn.Execute update tb_user set havein=0 where userid= & UsId & and UserType=0 End End If End Sub Private Sub Img_PswCancel_Click Pte_StuPsw.Visible = False ShowButton End Sub Private Sub Img_PswOk_Click On Error GoTo Err1 如果发生错误转向错误处理 Dim rs A

31、s New ADODB.Recordset 声明认识rs为记录集对象 Sql = select * from TB_User where UserId= & UsId & & _ and UserType=0 and UserPsw= & Txt_StuPsw.Text & 把验证密码的SQL语句赋给变量Sql rs.Open Sql, cnn, adOpenStatic, adLockReadOnly 执行SQL语句 If Not rs.RecordCount 0 Then 如果密码不正确 If MsgBox(密码不正确,请您重新填写!, vbOKCancel + vbCritical) =

32、 vbCancel Then 弹出提示框 Pte_StuPsw.Visible = False 如果单击取消回到开始考试的界面 Else 如果单击确定 Txt_StuPsw.Text = 清空Txt_StuPsw Txt_StuPsw.SetFocus 设置Txt_StuPsw获得焦点 End If Else Pte_UpdatePsw.Visible = True 显示修改密码的图片框 Txt_Id.Text = UsId 用户帐号中显示用户的帐号 Pte_StuPsw.Visible = False 隐藏输入验证码的图片框 Txt_Psw.Text = 清空Txt_Psw Txt_SecP

33、sw.Text = Txt_Psw.SetFocus 设置Txt_Psw获得焦点 End If Exit Sub 结束结束Sub过程 Err1: ErrMessageBox 校对密码出错 显示出错信息 End Sub Private Sub Img_Ok_Click On Error GoTo Err1 如果发生错误就转向错误处理 If Trim(Txt_Psw.Text) = Then 如果密码为空 MsgBox 密码不能为空!, vbOKOnly + vbCritical 提示输入密码 ElseIf Trim(Txt_Psw.Text) Trim(Txt_SecPsw.Text) Then

34、 如果两次密码不同 MsgBox 您两次输入的密码不一样!, vbOKOnly + vbCritical 提示重新输入密码 Txt_Psw.Text = 清空Txt_Psw Txt_SecPsw.Text = 清空Txt_SecPsw Txt_Psw.SetFocus 设置Txt_Psw获得焦点 Else 如果两次输入的密码相同且不为空 Sql = update tb_user set userpsw= & Txt_Psw.Text & & _ where userid= & UsId & 修改密码 cnn.Execute Sql 把密码写入数据库 MsgBox 修改成功!, vbOKOnly

35、 + vbInformation 提示修改成功 Pte_UpdatePsw.Visible = False Pte_UpdatePsw不可见 ShowButton End If Exit Sub 跳出Sub过程 Err1: ErrMessageBox 密码修改出错 显示提示信息 Call Form_Load End Sub Private Sub Img_Again_Click Txt_Psw.Text = Txt_SecPsw.Text = Txt_Psw.SetFocus End Sub Private Sub Img_Cancel_Click Pte_UpdatePsw.Visible

36、= False ShowButton End Sub Private Sub Men_AboutTest_Click frm_Dialog.Show End Sub Private Sub Men_Help_Click SendKeys F1 End Sub Private Sub Men_Sele_Click On Error GoTo Err1 Dim rs As New ADODB.Recordset Sql = select grade from tb_grade where stuid= & UsId & rs.Open Sql, cnn, adOpenStatic, adLockR

37、eadOnly MsgBox 您的考试成绩是: & vbCrLf & & rs.Fields(grade) & , vbOKOnly Exit Sub Err1: ErrMessageBox 查分失败 End Sub Private Sub meu_UpdatePsw_Click Pte_StuPsw.Visible = True Image1.Visible = False 用于标识的图像框不可见 frm_Stu.CmdOk.Visible = False 开始考试的命令按钮不可见 Begin.Visible = False 开始考试菜单不可见 Txt_StuPsw.Text = Txt_S

38、tuPsw.SetFocus End Sub Private Sub T_About_Click frm_About.Show End Sub Private Sub T_Exit_Click Unload Me End Sub Private Sub Txt_Psw_KeyPress(KeyAscii As Integer) If KeyAscii = 13 Then Txt_SecPsw.SetFocus End If End Sub Private Sub Txt_SecPsw_KeyPress(KeyAscii As Integer) If KeyAscii = 13 Then Call Img_Ok_Click End If End Sub Private Sub Txt_StuPsw_KeyPress(KeyAscii As Integer) If KeyAscii = 13 Then Call Img_PswOk_Click End If End Sub Private Sub ShowButton If HaveTest Then 如果参加考试的字段值为1

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 生活休闲 > 在线阅读


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号