ImageVerifierCode 换一换
格式:DOCX , 页数:26 ,大小:90.15KB ,
资源ID:11310563      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/11310563.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(数据库课程设计在线考试系统.docx)为本站会员(b****8)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

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

1、数据库课程设计在线考试系统 成绩:_数据库原理及应用课程设计课题 在线考试系统 班级 计06-7 组长 栾习文 组员 栾习文 2008 年 12 月 22日2009 年 1 月 4 日 在线考试系统1绪论随着标准化考试的日益普及,在各种考试中越来越多地采用了计算机考试的方式。相对于传统的卷面考试而言,由于传统的卷面考试从出题印刷到下发试卷等环节需要较长的时间,接触的人员相对较多,因而在保密方面具有一定的困难。而计算机考试系统采用试题库方式提供试题来源,考前无任何成套试卷,考试时考卷由计算机现场随机生成,各考生试卷不完全相同,从而避免了互相参看等作弊现象或不公平成绩的出现。同时也可考后即可获得成

2、绩,省去了人力评卷的麻烦和弊端。2需求说明对考生而言,分为五个考试状态:待考、就绪、考试中、结束、缺考。考生用准考证号登录考试网站,然后验证考生信息是否一致,如果一致就会停留在考生须知界面,处于就绪状态。所有考生等待服务器发送统一命令分发试卷并同时进入考试中状态。在开考后20分钟后考生仍未到场,考生状态会自动设置为“缺考”,不能参加此次考试。考试过程中可自由答题(可随时定位到每一题)。如果有考生信息不一致的情况,可上报管理员,经审核后进行修改。考生考完试点击“交卷”,经确认后交卷。考后即可查看考试分数。在到达考试时间后,服务器会自动给未交卷的考生结束考试,并可同时给所有考生评卷得出分数。对管理

3、员而言,可以更改数据库的所有内容,可添加、查询、修改、删除考生的信息,设置考试的相关内容。可有选择地录入试题,为题目分类并自动在正确答案表里插入相应的标准答案。开考前服务器可自动为每考生随机生成试卷。考生号由管理员统一设置。服务器会根据考试时间来自动设置考生的考试状态。到达考试时间后,服务器可同时让所有在线考生进入答题阶段。在考试过程中,自动为考生保存考试答案。也可以查看所有考生的在线考试情况。同时也可为出现异常的考生延时等详细功能。考试全部结束后,服务器会备份所有考生信息和答题情况,并给所有考生评卷并生成所有考试成绩表,以便考生查分。3概念模型设计针对以上的功能分析,对数据库的设计做了以下分

4、析。考虑到在线考试的特殊要求,数据库的设计应该包含以下信息:考生的基本信息用来在考生登陆时进行核对验证,防止考生信息录错的情况。考生考试的基本信息用来控制考试时间和考生的考试状态,统计在线考生和缺考情况,同时也方便服务器统一发送命令,给所有考生同时开始考试和结束考试。从而体现公平一致的原则。题库应包含所有的考试类型、题目内容和每题的分值,以便以后的随机抽题和为考生评分。并且数据库里也存储有每题对应的正确答案,考生的考试答案,这样可以方便评分。还对考生答案做了备份,方便以后的查阅和总结考试情况,以进一步更新考试,提高考试质量。还应把给每位考生随机生成的试题保存起来,方便查阅核对,并可由服务器统一

5、给对应考生发送试卷。最后把评卷的结果和考生成绩统计出来做备份,考生可在考试结束后直接查看考试结果。如果发现有疑问地方也可随时查看和核对。由此分析一共设计了七张表用来存储所有的考生信息和考试信息:考生信息表(包含属性:姓名、性别、准考证号、身份证号、所在学校)、考生考试信息表(包含属性:考生号、准考证号、考试时间、考试状态)、题库表(包含属性:题号、题目、题目类型、分值)、正确答案表(包含属性:题号、标准答案)、考生试卷表(包含属性:题号、考生号)、考生答案表(包含属性:题号、答案、考生号)和考生成绩表(包含属性:准考证号、成绩)。并为每个表设置了能唯一确定每位考生的属性。其中考生信息表里设置属

6、性(准考证号)为主关键字,并在考生考试信息表和考生成绩表里设置属性(准考证号)为考生信息表中属性(准考证号)的外部关键字。这样就可一一关联和对应每一位考生的信息。在考生考试信息表里为每位考生生成一属性(考生号)并设置其为此表的主关键字。以唯一确定每一位考生的考试时间和考试状态。在题库中设置属性(题号)为主关键字,这样就可以唯一确定每一题,防止题目的重复,也方便随机为考生抽题。并在考生试卷表、正确答案表和考生答案表里设置属性(题号)为外部关键字,这样就和题库中的题号一一对应起来,可减少这些表中的属性。从而实现整个数据库设计的完整性和一致性。在考生答案表和考生试卷表中同时设置属性(题号和考生号)为

7、外部关键字,这样就把考生和题目联系起来。通过关联唯一确定每位考生的试卷和答案,也方便了以后的分发试卷和为每位考生评卷。(1)考生信息和考生考试信息之间的联系:(2)题库和考生试卷之间的联系(3)考生试卷和考生试卷之间的联系 (4)题库和正确答案之间的联系(5)考生信息和考生成绩之间的联系在线考试系统模型整体E-R图4逻辑设计整体逻辑数据库结构如下: 下面是将各个实体和联系转化为相应的二维表即关系模式,指定各个关系的主关键字和外部关键字,并对各个关系的约束加以限定:考生信息表字段名数据类型主关键字外部关键字参照的表取值说明姓名varchar(8)不允许为空性别char(2)只允许取“男”或“女”

8、准考证号char(6)Yes数字字符身份证号char(18)数字字符所在学校varchar(16)考生考试信息表字段名数据类型主关键字外部关键字参照的表取值说明考生号char(5)Yes准考证号char(6)Yes考生信息数字字符考试时间char(22)不允许为空考试状态varchar(6)不允许为空题库表字段名数据类型主关键字外部关键字参照的表取值说明题号intYes大于0题目varchar(100)不允许为空题目类型int 1或2或3分值int分值in(1,10)备注:其中题目类型中:1-判断题 2-填空题 3-选择题正确答案表字段名数据类型主关键字外部关键字参照的表取值说明题号intYe

9、s题库大于0标准答案varchar(20)Not null考生试卷表字段名数据类型主关键字外部关键字参照的表取值说明题号intYes题库大于0考生号char(5)Yes考试考试信息Not null考生答案表字段名数据类型主关键字外部关键字参照的表取值说明题号intYes题库大于0答案Varchar(20)可为空考生号Char(5)Yes考生考试信息Not null考生成绩表字段名数据类型主关键字外部关键字参照的表取值说明准考证号Char(6)Yes考生信息数字字符成绩int成绩in(0,100) 缺省为05物理设计建立数据库:CREATE DATABASE 在线考试系统ON ( NAME =在

10、线考试系统, FILENAME = c:在线考试系统.mdf, SIZE = 10, MAXSIZE = 50, FILEGROWTH = 5 )LOG ON( NAME = library, FILENAME = c:在线考试系统.ldf, SIZE = 5MB, MAXSIZE = 25MB, FILEGROWTH = 5MB )数据库建表:考生信息表CREATE TABLE ksxx( sno int PRIMARY KEY IDENTITY, 姓名 varchar(8) NOT NULL, 性别 char(2), 准考证号 varchar(6), 身份证号 varchar(18), 所

11、在学校 varchar(16), )考生考试信息表CREATE TABLE ksksxx( sno int PRIMARY KEY IDENTITY, 考生号 varchar(5) NOT NULL, 准考证号 varchar(6), 考试时间 varchar(22) NOT NULL, 考试状态 varchar(6) NOT NULL, )题库表CREATE TABLE tk( sno int PRIMARY KEY IDENTITY, 题号 int, 题目 varchar(10), 题目类型 int, 分数 int,)正确答案表CREATE TABLE zqda( sno int PRIM

12、ARY KEY IDENTITY, 题号 int, 标准答案 varchar(20) NOT NULL, )考生试卷表CREATE TABLE kssj( sno int PRIMARY KEY IDENTITY, 题号 int, 考生号 varchar(5) NOT NULL,)考生答案表CREATE TABLE ksda( sno int PRIMARY KEY IDENTITY, 题号 int, 答案 varchar(20), 考生号 char(5) NOT NULL,)考生成绩CREATE TABLE kscj( sno int PRIMARY KEY IDENTITY, 准考证号 C

13、har(6), 成绩 int,)为了改善和优化数据库的性能和查询效果,为每个表创建了索引,具体代码如下: /*考生信息表索引*/create unique index index_ksxx on ksxx(姓名,准考证号)/*考生考试信息表索引*/create unique index index_ksksxx on ksksxx(考生号)create unique index index_ksksxx1 on ksksxx(准考证号)/*题库表索引*/create unique index index_tk on tk(题号)/*正确答案表索引*/create unique index in

14、dex_zqda on zqda(题号)/*考生答案表索引*/create unique index index_ksda on ksda(题号,考生号)/*考生试卷表索引*/create unique index index_kssj on kssj(考生号,题号)/*成绩表索引*/create unique index index_kscj on kscj(准考证号)为了实现表间数据的一致性和完整性,创建了触发器,具体代码如下:/*考生信息表触发器*/create trigger trigger_ksxx1 on ksxxfor insert,update,deleteasif (SELE

15、CT LEN(准考证号) FROM inserted)6beginraiserror(准考证号长度不对!,10,1)rollback transactionendelsebeginprint 添加成功!endif exists(select * from inserted where 身份证号 in(select 身份证号 from ksxx)begin print 身份证号已经存在!returnend/*考生考试信息表触发器*/create trigger trigger_ksksxxon ksksxxfor insert,update,deleteasif exists(select *

16、from inserted where 准考证号 in(select 准考证号 from ksksxx)beginraiserror(准考证号重复!,16,1)rollback transactionendif not exists(select * from inserted where 考试时间 like %-%-%+ +%:%-%:%)beginraiserror(时间格式不对!,16,1)rollback transactionendif not exists(select * from inserted where 考试状态 in(待考,就绪,考试中,结束,缺考)beginraise

17、rror(状态错误!,16,1)rollback transactionend/*题库表触发器*/create trigger trigger_tkon tkfor insert,update,deleteasif exists(select * from inserted where 题目 in(select 题目 from tk)beginraiserror(题目重复!,16,1)rollback transactionendif exists(select * from inserted where 题目 like %?and 题目类型=2)beginraiserror(题目类型错误!,

18、16,1)rollback transactionend/*正确答案表触发器*/create trigger trigger_zqdaon zqdafor insert,update,deleteasif exists(select * from inserted where 题号 in(select 题号 from zqda)beginraiserror(题号重复!,16,1)rollback transactionend/*考生答案触发器*/create trigger trigger_ksdaon ksdafor insert,update,deleteasif not exists(s

19、elect * from inserted where 题号0 and 题号(select count(题号) from tk)beginraiserror(题号不在范围之内!,16,1)rollback transactionendif not exists(select * from inserted where 考生号 in(select 考生号 from ksksxx where 考试状态=考试中)beginraiserror(考生号有误!,16,1)rollback transactionend/*考生试卷触发器*/create trigger trigger_kssjon kssj

20、for insert,update,deleteasif exists(select * from inserted where 考生号 in(select 考生号 from kssj)beginraiserror(考生试卷已生成!,16,1)rollback transactionend/*考生成绩表触发器*/create trigger trigger_kscjon kscjfor insert,update,deleteasif exists(select * from inserted where 准考证号 in(select 准考证号 from ksksxx where 考试状态=结

21、束)beginraiserror(准考证号错误!,16,1)rollback transactionend对在线考试系统功能的描述,针对各功能,创建了不同的存储过程来实现,这样不但可以反复调用这些程序,大大减少了客户端的处理事务,同时也充分发挥服务器的功能,尽量减少网络上的堵塞。根据查询功能的需要,我创建了相应的视图,基于视图创建了相应的查询存储过程,这些存储过程还包括对各表内容信息的添加、删除和更新。并且在存储过程中也相应地加入了对数据完整性和一致性的约束条件。同时还创建了为指定考生或所有考生随机生成试卷和对指定考生或所有考生评卷功能的存储过程。(1)为所有考生随机生成试卷的存储过程的功能实

22、现可简略为:我先创建了一个游标,用来暂时保存在线考试的考生的考生号,然后采用双重while循环,外层循环用来控制游标,一条一条地读取考生号,内层循环用来为游标所定位的考生随机生成试题(我这里为了演示,只随机生成了5到题)。当游标结束时,也就为所有的考生生成了试卷。所谓随机就是用rand()函数在所有题号(例如1-100)之间随机生成一个随机数,由这个随机数唯一对应题库中的一道题目。具体代码如下:/*给单一考生生成试卷*/create proc pro_kssj_sj(ksh char(5)=null)asif not exists(select * from ksksxx where 考生号=

23、ksh)beginprint 非法考生号!returnendif (select count(*) from kssj where 考生号=ksh)5beginwhile (select count(*) from kssj where 考生号=ksh)5begininsert into kssj values(1+cast(rand()*10 as int),ksh)endreturnendelsebeginprint 题目已生成!endexec pro_kssj_sj S0001 /*执行示例*/*给所有考生生成试卷*/create proc pro_all_kssjasif not ex

24、ists(select * from ksksxx)beginprint 暂无考试考生!returnendelsebegindeclare cursor_all_kssj insensitive cursorfor select 考生号 from ksksxxfor read onlydeclare ksno char(5)open cursor_all_kssjfetch next from cursor_all_kssj into ksnowhile(fetch_status=0)beginwhile (select count(*) from kssj where 考生号=ksno)5b

25、egininsert into kssj values(1+cast(rand()*10 as int),ksno) endfetch next from cursor_all_kssj into ksnoendclose cursor_all_kssj -关闭游标deallocate cursor_all_kssj -释放游标print 试卷已生成!endexec pro_all_kssj /*执行示例*/(2)为所有考生评卷功能的存储过程具体实现过程如下:创建一游标读取考生答案表里的所有信息,同样采用的是双重while循环来实现此功能。外层循环用来控制游标,并定义两个临时变量temp和su

26、m,然后用内层循环来把考生答案和正确答案进行比较,如果结果一致,用变量temp从题库表中读取此题的分值,用变量sum来累加分值,由于每位考生只有5道题,故内层循环只循环5次,最后变量sum中数值即位此考生的最后成绩,并通过存储过程pro_insert_cj(向考生成绩表中插入成绩)把考生成绩插入考生成绩表中。如此循环下去,直到游标结束,即位所有考生评卷过程结束。考生成绩表中也自动加入了每位在线考试的考生的分数。具体实现代码如下:/*给单一考生评分存储过程*/create proc pro_pf(ksno char(5)asdeclare cursor_pf insensitive cursor

27、for select 题号,答案 from ksda where 考生号=ksnofor read onlyif not exists(select * from ksksxx where 考生号=ksno and 考试状态=结束)beginraiserror(考生考试还未结束!,16,1)rollback transactionendelsebeginprint 考试已结束,继续!endif not exists(select * from kssj where 考生号=ksno)beginprint 没有此考生的答案!returnendelsebeginopen cursor_pfdecl

28、are name sysname,result sysname,sum int,temp int,temp1 int,zkzh char(6)fetch next from cursor_pf into name,resultselect sum=0select temp=1select temp1=1while(temp1=5)beginif exists(select * from zqda where 题号=name and 标准答案=result)beginselect temp=(select 分值 from tk where 题号=name)select sum=sum+tempselect temp1=temp1+1-print haha-print sumfetch next from cursor_pf into name,resultendelsebeginselect temp1=temp1+1fetch next from cursor_pf into name,resul

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1