理工学院考试成绩分析PB+SQL2000计算机毕业设计(论文).doc

上传人:文库蛋蛋多 文档编号:4029205 上传时间:2023-04-01 格式:DOC 页数:57 大小:429.50KB
返回 下载 相关 举报
理工学院考试成绩分析PB+SQL2000计算机毕业设计(论文).doc_第1页
第1页 / 共57页
理工学院考试成绩分析PB+SQL2000计算机毕业设计(论文).doc_第2页
第2页 / 共57页
理工学院考试成绩分析PB+SQL2000计算机毕业设计(论文).doc_第3页
第3页 / 共57页
理工学院考试成绩分析PB+SQL2000计算机毕业设计(论文).doc_第4页
第4页 / 共57页
理工学院考试成绩分析PB+SQL2000计算机毕业设计(论文).doc_第5页
第5页 / 共57页
点击查看更多>>
资源描述

《理工学院考试成绩分析PB+SQL2000计算机毕业设计(论文).doc》由会员分享,可在线阅读,更多相关《理工学院考试成绩分析PB+SQL2000计算机毕业设计(论文).doc(57页珍藏版)》请在三一办公上搜索。

1、理工学院考试成绩分析第一章 绪 论PB8.0是PowerBuilder诞生10年来最新的一个版本,被认为是当今最具影响力的4GL/RAD开发工具。Sybase公司8月2日推出最新版本的应用开发工具PB8.0 (PowerBuilder 8.0)。PB8.0通过诸多创新特性以及与应用服务器的无缝集成,提供了基于客户机/服务器、Web及多层结构的快速开发环境。同时,卓越的应用开发效率及强大的Web功能为新版本增色不少。 PowerBuilder 80是什么Sybase PowerBuilder 8.0是易于使用的、可伸缩的、并经实践证明的快速集成开发环境,它在给用户提供一条转移到下一代平台的途径的

2、同时,使用户仍能够保护和扩展他现有的在技术和应用上的投资。多年来,用户一直赞赏PowerBuilder 用于客户机/服务器应用开发的快捷性、简便性以及先进性。现在,用户可以在他熟悉的相同的PowerBuilder环境中使用相同的技术来创建同样的功能强大的Web和分布式应用。PB8.0新版增加了许多强大的功能,包括卓越的应用开发效率,与Sybase EAServer的紧密集成以及强大的Web应用开发能力,具体表现在三个方面:在Java应用开发方面,PB8.0使PowerBuilder的代码能够在EAServer服务器内部与Java、C、C+,以及与其它组件一道执行。在客户机/服务器应用的开发方面

3、,PB8.0增加了国际化支持、扩展的数据库支持、增强的AutoScript功能、例外处理功能的支持。在将客户机/服务器应用移植到Web方面,PB8.0则提供对统一的用户界面、工作区与对象的支持,简化的Web站点创建、基于事件驱动体系结构的高效页面开发功能,以及与EAServer增强的集成。从熟悉的PowerBuilder环境中,客户就可以充分地利用大量新的Web应用开发功能,将应用、用户以及技术带到Web世界与分布式计算领域。卓越开发效率PowerBuilder通过提供大量新的功能和特征,继续拓展其快速应用开发和无比卓越的生产率传统,显著地加快了应用开发的周期。工作区与对象新的工作区意味着你能

4、够同时而且高效率地创建、预览和部署多个应用。在工作区中,你可以创建“对象”-你部署的最终产品。目前,PowerBuilder具有三种类型的对象, 它们是基于Windows的应用、部署到EAServer 中的PowerBuilder组件、以及Web对象。系统目录树这一激活的、自动缩进的、适合浏览的资源,以分层的格式可视化地显示工作区中的内容、HTML页面、Web应用可用的语言,以及驻留在EAServer中的组件。它还使你能够拖放组件和对象,从而使程序代码的编写量降到最低。例外处理 PowerBuilder 8.0现在包含例外处理类和语法分析功能,用于对应用程序内部的上下文相关的错误分析处理。你可

5、以很轻松地处理来自 EAServer组件的例外,定义和丢弃你自己的例外类型。内置的国际化支持PowerBuilder现在支持双字节字符集。数十项可用性增强 Sybase公司已把50个以上增强的可用性增加到开发环境中。Web的快速应用开发PowerBuilder 8.0现在是一个综合性的Web集成开发环境,它提供了一个基于图形用户界面、功能强大而快捷的环境,用于高级Web应用和Web站点的创建。从熟悉的PowerBuilder环境中,你可以充分地利用大量新的Web应用开发功能,将你的应用、你的用户以及你的技术带到Web世界与分布式计算领域。无论是从事企业级系统开发,还是从事商业应用软件开发,高度

6、灵活性、快速性以及强大的功能都是你所需要的。而这些正是Sybase PowerBuilder 8.0所能提供的。借助于PowerBuilder,你能够创建、增强和扩展驱动当今商务运作的客户机/服务器应用。而且,你还能够快速地创建并充分利用新的Internet和分布式体系结构优势的复杂Web及多层应用。紧密集成EAServer EAServer是Sybase公司的一个独具特色的应用服务器,它融合了组件事务处理服务器和动态页面服务器的功能。 这就是PowerBuilder提供与J2EE应用服务器EAServer之间无缝集成用于应用开发、测试、调试和部署过程的原因。利用EAServer,你就能够支持

7、包括CORBA、JavaBeans与Enterprise JavaBeans、COM与C/C+组件在内的不同种类的组件模型以及本地PowerBuilder组件。EAServer还提供了你部署全球应用所需要的负荷平衡、高可用性、高安全性,以及高伸缩性特性。 IDEChanges : PB8.0用诸多细致的视觉手法进一步改进了它的IDE(集成开发环境),由此反映出该产品在结构上的一些重大改变,包括了开发人员生产力、web客户开发和EAServer集成三个方面的重要升级。 Workspaces和系统树窗口 PB8.0提供的Workspace使开发人员可以同时在多个应用或者组件上工作。系统树窗口为开发

8、人员提供了一个关于Workspace的活动状态视图,所有的组件、功能、属性、事件和结构都可以通过系统树窗口来访问。 输出窗口和剪贴(Clip)窗口 PB8.0新增了输出窗口和剪贴窗口。系统树窗口和Workspace的强大功能,再加上输出窗口、剪贴窗口的帮助,PB8.0的IDE已经有了显著的改进。 与PowerSite合并 将PowerSite完全整合进PB8.0,使PB8.0能够轻松建立事务型Web应用,同时也消除了Sybase产品线的重叠。 EAServer整合 存在于EAServer上的PB8.0应用程序和不可视对象现在可以与EJB组件直接进行通信,从而为开发人员提供了更好的组件间的互操作

9、能力以及与EAServer更好的集成,普及并简化了PB8.0的组件化开发。 Web功能 将PowerSite整合进PB,使得PowerBuilder可以开发扩展的瘦客户应用,而增加瘦客户功能对促进Web应用开发是不可或缺的。 Sybase做了很多努力来满足PB用户的需求,让他们发现这些新特性对他们构建或维护两层事务型应用非常有用。同时,Sybase希望这些新特性也能告诉所有人,PowerBuilder8.0能够轻松构建更为复杂的n层和以Web为中心的应用。使用PowerBuider可以快速地开发出当今最流行的各种商业应用,如客户/服务器应用、分布式应用、基于组件的应用和Web应用。在Power

10、Buider8.0强大的功能和友好的集成开发环境支持下,开发人员的效率得到空前的提高,是程序设计与开发工作变的更加有趣,仿佛是一个艺术家在创作一件艺术品,因此它深受国内外广大开发人员的喜爱。作为一名企业应用的开发人员,你必须紧跟市场和企业规则的变化,不断地为企业用户开发出优质的应用系统,以使企业能在信息时代立于不败之地。选择PowerBuider8.0,定能使你从容应对各种变化,在激烈竞争环境中游刃有余。在满足用户和完成系统的需要前提下,我们认为选用PowerBuider8.0来开发本次毕业设计课题是最佳选择。Sybase做了很多努力来满足PB用户的需求,让他们发现这些新特性对他们构建或维护两

11、层事务型应用非常有用。同时,Sybase希望这些新特性也能告诉所有人,PowerBuilder8.0能够轻松构建更为复杂的n层和以Web为中心的应用。 第二章 可行性分析 为了以最小的代价在尽可能短的时间内确定问题是否能够解决,在进行设计开发前首先进行了可行性分析。 考试是教学过程的重要环节,认真、严密的考试过程,科学、准确的结果分析可以为评价教学效果,以及提高教学质量、改进教学方法和教学管理工作提供可靠的依据。 a、新学期开始时,对应每一位新生输入相关的详细记录。 b、建立各类课程的详细记录。 c、各专业每学期要选择各类课程安排本学期的教学计划。 d、各个对应专业年纪的学生可选择教学计划范围

12、内的课程或选择重修课程并在每学期末输入成绩。e、随时可对学生记录、课程信息及学生成绩进行查询并且统计分析。f、只有有权限的人才可以对数据库进行维护。第三章 需求分析学生成绩管理工作被视作高校管理工作中一项不容忽视的重要分支,其工作量大,涉及面广,学生成绩管理工作进行的好坏直接影响着整个高校管理工作的各个环节。由于成绩管理工作的本身特点及特殊性质,单纯依靠人力,会使从事这项工作的管理人员过度疲劳,难免会发生许多错误,难以做到管理的规范化,这不符合管理工作的令后发展趋势。因此,需要开发一种功能全面,操作简便的管理系统来辅助作用,人机配合,能够使机器承担部分工作,是管理员逐步摆脱一些无谓的,烦琐的业

13、务,这对充分利用人力资源的主导作用及使管理工作逐步步入规范化轨道有着重要意义。根据上一章可行性研究及对用户调查,我们可确定本系统必须完成的工作,下面将来做简单介绍。1 输入部分新学期开始需将学生基本信息输入,一般来讲,学生基本信息有姓名,学号,还有学生所属专业。在学生基本信息里可以选择同样专业的学生,可以对学生基本信息进行修改。每个新学期的信息都不同,还要设置学期。在设置专业时要设专业名称和专业代号,以便查询或者维护。每学期末应输入学生的各门课程成绩,但必须是该学生所在专业年级在本学期开了这门课,所以输入部分还需试卷登记,在试卷登记里要详细区分每个专业,每个班级的试卷。试卷登记就需要试卷信息。

14、在输入模块里需要专业设置,学期设置,学生信息,试卷登记,试卷信息。该部分是本系统最重要部分,着重分析,还应考虑数据的完整性,使用视图。2 统计分析部分为了是各项记录可供有关人员随时查询,统计分析当中需要查询部分,查询应可以用按学生学号和学生姓名检索该学生的所有信息。期末考试结束后,各教研室应至少要抽取一个授课班进行试题的难度,区分度分析。A考试难度指数(P)值的计算方法:客观题难度指数计算公式:P=R/N(R为某一题参加考试的学生中答对的人数,N为参加考试的学生数。)非客观题难度指数计算公式:P=X/W(X为某题的平均分,W为该题的最高分值)B试题区分度(D)值的计算方法:计算某一班学生答某一

15、题的区分度,首先要在该班中确定一个高分组,一个第分组。在考生中按名次排列位于前25%的学生为高分组,位于后25%的学生为底分组。客观题分度计算公式:D=Ph-Pl(Ph为高分组学生答对的百分比,Pl为底分组学生答对的百分比)难度指数和区分度计算完后要在教研室同考试题一同存档,为以后的命题工作提供依据。另外试题的难度情况和区分度情况要写入下表考试总结和成绩分析中。标准差:数据离散趋势最灵敏、最标准的指标,能准确反映数据的差异程度,是对数局进行同意分析的前提与基础。客观题:评分而得名。试题类型有概念题、见大题、天空题、排列题、多重选择题等。优点:有明确的标准答案,简单,题量多,有足够的覆盖率:缺点

16、:难于测量综合、平分两级复杂的认知目标。区分度:用极端分组把学生按其水平分开的能力。具有良好的能力。具有良好的句粉能力的测验能使水平高的学生得高分,水平低的学生得低分,因此,区分度通常作为测验是否具有效应的“显示器”,是坚定试题质量、筛选试题的主要指标与依据。学生成绩统计专业年级考试人数缺考人数平均成绩标准差各额分数段人数缺考学生名单9080706060学生考试成绩频数分布图第四章 总体设计 本次设计选择powerbuilder8.0为开发工具,以mirocsoft SQL server2000分布式客户服务器数据库系统,作为数据库后台,windows2000操作平台。学生成绩分析系统是一个很

17、大的系统,若要求一个人独立地较完善地完成各项功能,在如此短暂的时间内简直是天方夜谈。所以,我侧重于输入模块进行了本次设计。下面我将分为两部分介绍总体设计。本课题采用Microsoft SQL Server2000作为数据库后台,SQL语言功能丰富,使用方式灵活,语言简洁易学,它的功能包括查询,操纵,定义和控制4个方面。它的主要特点是:一体化,联机交互使用和嵌入式有统一的语法结构,过度非过程化以及语言简洁,易学易用等。程序设计: 对整个系统动能有了总体上的认识之后,应对每一个模块的任务有一个清晰的认识,以防代码重复,责任模糊而浪费不必要的工作量。下面谈一谈我对每一个模块总体认识。1 数据输入:

18、a、 专业设置:可新增输入专业代码及专业名称。也可以删除专业代码及其专业名称 b、学期设置:可新增输入学期 c、学生信息:可新增输入学号,姓名和专业。 d、试卷登记:显示各专业每个学期的试卷登记信息。 e、试卷信息:显示各专业每个学期的每一学生的试卷信息、即考试成绩。2 统计分析模块: a、查找学生:可以按学号进行查询也可按姓名进行查询。 b、成绩统计和频数分布图。 c、成绩分析。3 退出系统。SQL的数据定义包括3部分:定义基本表,定义视图和定义索引。视图是从一个或几个基本表(或视图)导出的表。在应用系统中视图是极其重要组成部分。它的外模式是由若干基本表和若干视图组成的,视图是一个虚表。它的

19、优点有:1 对于数据库的重构造提供了一定程度上的逻辑独立性。2 简化了用户观点3 视图的机制是不同的用户能以不同的方式看待同一数据。4 视图的机制对机密数据提供了自动的安全保护功能。索引是数据库检索经常用到的对象,为了提高查找速度应该给表建立索引。索引可以是唯一的或不唯一的,可以是簇类的或非簇类的。对一个基本表,可以根据应用环境的需要建立若干索引,以提供多种存取路径,提高系统的运行速度。根据以上分析将数据库设计成若干个基本表,它们是Paper试卷信息含 义字 段 名类 型长 度主 键专业代码Spec_codeChar7学 期SemesterChar9第一题分数Due1Tinyint1第二题分数

20、Due2Tinyint1第三题分数Due3Tinyint1第四题分数Due4Tinyint1第五题分数Due5Tinyint1第六题分数Due6Tinyint1第七题分数Due7Tinyint1第八题分数Due8Tinyint1第九题分数Due9Tinyint1第十题分数Due10Tinyint1说明:a、 专业代码和学期作为主码。b、 Due1Due10均为该题目满分成绩。Score成绩信息含 义字 段 名类 型长 度主 键学生学号Stu_idChar10学 期SemeterChar9第一题分数Score1Float8第二题分数Score2Float8第三题分数Score3Float8第四题

21、分数Score4Float8第五题分数Score5Float8第六题分数Score6Float8第七题分数Score7Float8第八题分数Score8Float8第九题分数Score9Float8第十题分数Score10Float8是否缺考absentTinyint1说明:a、 学生学号为主键。b、 Score1Score10为该学生在考试中取得的考试分数。c、 是否缺考、默认值为0,即为不缺考Student学生信息含 义字 段 名类 型长 度主 键学生学号Stu_idChar10学生姓名Stu_nameChar10专业代码Spec_codeChar7说明:a、 学生学号为主码。Semete

22、r学期信息含 义字 段 名类 型长 度主 键学 期semeterchar9说明:a、学期为主码。Specicalty专业信息含 义字 段 名类 型长 度主 键专业代码Spec_codechar7专业名称Spec_namechar22说明:a、 专业代码为主码。各表之间的关系第五章 详细设计本章将想次地对各个模块进行分解和剖析,包括程序、变量使用和窗体的构成等。系统氛围四个模块,下面依次对各个模块进行叙述。基本界面:专业设置窗口:数据窗口dw_1连接dataobject:dw_spec学期设置:数据窗口dw_1连接dataobject:dw_xueqi SELECT semester.semes

23、ter FROM semester 学生基本信息:数据窗口dw_1连接dataobject:dw_xueshengxinxi代码部分: SELECT student.stu_id, student.stu_name, student.spec_code FROM student WHERE student.spec_code = :scode 试卷登记:数据窗口dw_1连接dataobject:dw_analysisSELECT specialty.spec_name, paper.semester, paper.due1, paper.due2, paper.due3, paper.due4

24、, paper.due5, paper.due6, paper.due7, paper.due8, paper.due9, paper.due10, paper.spec_code FROM paper, specialty WHERE ( paper.spec_code = specialty.spec_code ) and ( ( paper.spec_code = :spec ) AND ( paper.semester = :semes ) ) 试卷信息:数据窗口dw_1连接dataobject:dw_analysis控键:tv_1代码:treeViewItem tvithis.Get

25、Item(handle,tvi)var_spec = tvi.datathis.hideselection = falseparent.init_score()控键:tv_2代码:treeViewItem tvithis.GetItem(handle,tvi)var_semeter = tvi.datathis.hideselection = falseparent.init_score()查找学生:数据窗口dw_1连接dataobject:dw_analysis检索:string get_strget_str = trim(sle_1.text)if sle_1.text = thenret

26、urnend ifchoose case tab_1.selectedtabcase 1dw_1.dataObject = dw_find_stu_by_iddw_1.setTransObject(sqlca)dw_1.retrieve(get_str)case 2dw_1.dataObject = dw_find_stu_by_namedw_1.setTransObject(sqlca)dw_1.retrieve(get_str)end choose成绩统计和频数分布图:DataWindowChild dwc_score, dwc_absent,dwc_graphdw_1.GetChild(

27、dw_score, dwc_score)dw_1.GetChild(dw_graph1,dwc_graph)if var_semester thendecimal there_paperSELECT top 1 paper.due1 INTO :there_paper FROM paper WHERE ( paper.semester = :var_semester ) ; if sqlca.sqlcode 0 thenmessagebox(错误,您所指定的专业在指定的学期不存在试卷!)dwc_score.SetTransObject(SQLCA)dwc_score.Retrieve()dwc

28、_graph.SetTransObject(SQLCA)dwc_graph.Retrieve()return end ifdwc_score.SetTransObject(SQLCA)dwc_score.Retrieve(var_semester)dwc_graph.SetTransObject(SQLCA)dwc_graph.Retrieve(var_semester,var_spec)elsedwc_score.SetTransObject(SQLCA)dwc_score.Retrieve()dwc_graph.SetTransObject(SQLCA)dwc_graph.Retrieve

29、(,)end if成绩分析:DataWindowChild dwc_section1,dwc_section2dw_1.GetChild(dw_section1, dwc_section1)/dw_1.GetChild(dw_section2, dwc_section2)if var_semester thendecimal there_paper6,10SELECT top 1 paper.due1, paper.due2, paper.due3, paper.due4, paper.due5, paper.due6, paper.due7, paper.due8, paper.due9,

30、paper.due10 INTO :there_paper1,1, :there_paper1,2, :there_paper1,3, :there_paper1,4, :there_paper1,5, :there_paper1,6, :there_paper1,7, :there_paper1,8, :there_paper1,9, :there_paper1,10 FROM paper WHERE ( paper.semester = :var_semester ) ; if sqlca.sqlcode 0 thenmessagebox(错误,您所指定的专业在指定的学期不存在试卷!)dw

31、c_section1.SetTransObject(SQLCA)dwc_section1.Retrieve()/dwc_section2.SetTransObject(sqlca)/dwc_section2.retrieve(,)return end ifint var_questions = 1 /get questins numbersfor var_questions=1 to 10if there_paper1,var_questions = 0 then EXITnextvar_questions -= 1/calculate difficultreal temp2,10SELECT

32、 sum( case when paper.due1=score.score1 then 1 else 0 end), sum( case when paper.due2=score.score2 then 1 else 0 end), sum( case when paper.due3=score.score3 then 1 else 0 end), sum( case when paper.due4=score.score4 then 1 else 0 end), sum( case when paper.due5=score.score5 then 1 else 0 end), sum(

33、 case when paper.due6=score.score6 then 1 else 0 end), sum( case when paper.due7=score.score7 then 1 else 0 end), sum( case when paper.due8=score.score8 then 1 else 0 end), sum( case when paper.due9=score.score9 then 1 else 0 end), sum( case when paper.due10=score.score10 then 1 else 0 end),avg( sco

34、re.score1), max(score.score1), avg( score.score2), max(score.score2),avg( score.score3), max(score.score3),avg( score.score4), max(score.score4),avg( score.score5), max(score.score5),avg( score.score6), max(score.score6),avg( score.score7), max(score.score7),avg( score.score8), max(score.score8),avg

35、( score.score9), max(score.score9),avg( score.score10), max(score.score10)INTO :there_paper2,1, :there_paper2,2, :there_paper2,3, :there_paper2,4, :there_paper2,5, :there_paper2,6, :there_paper2,7, :there_paper2,8, :there_paper2,9, :there_paper2,10, :temp1,1,:temp2,1,:temp1,2,:temp2,2,:temp1,3,:temp

36、2,3,:temp1,4,:temp2,4,:temp1,5,:temp2,5,:temp1,6,:temp2,6,:temp1,7,:temp2,7,:temp1,8,:temp2,8,:temp1,9,:temp2,9,:temp1,10,:temp2,10 FROM score, paper, student WHERE ( score.semester = paper.semester ) and ( paper.spec_code = student.spec_code ) and ( score.stu_id = student.stu_id ) and ( ( score.sem

37、ester = :VAR_SEMESTER ) AND ( score.absent = 0 ) ) ; int stu_nums stu_nums = there_paper2,var_questions+1 /the number of students int i for i = 1 to var_questionsthere_paper2,i = round( there_paper2,1 /stu_nums, 2) next if temp2,var_questions = 0 thenthere_paper2,var_questions = 0elsethere_paper2,va

38、r_questions = round(temp1,var_questions / temp2,var_questions, 2)end ifreal data_trans8for i = 1 to var_questionschoose case there_paper2,icase 0 to 0.30data_trans1 += 1case 0.31 to 0.50data_trans2 += 1case 0.51 to 0.70data_trans3 += 1case 0.71 to 1data_trans4 += 1end choosenextfor i = 1 to 4data_tr

39、ansi = round( 100*data_transi / var_questions, 2)nextdwc_section1.SetTransObject(SQLCA)dwc_section1.Retrieve()/dwc_section2.SetTransObject(sqlca)/dwc_section2.retrieve(var_semester,var_spec)if dwc_section1.rowCount() = 0 thendwc_section1.insertRow(0)end ifdwc_section1.setItem(1, difficult30,data_Tra

40、ns1)dwc_section1.setItem(1, difficult50,data_Trans2)dwc_section1.setItem(1, difficult70,data_Trans3)dwc_section1.setItem(1, difficult100,data_Trans4)/calculate partitiondatastore ds_difficultds_difficult = create dataStoreds_difficult.dataObject = dw_analysis_top25ds_difficult.setTransObject(sqlca)d

41、s_difficult.retrieve(var_semester,var_spec)stu_nums = ds_difficult.getItemdecimal(1,compute_stu_num)for i = 1 to var_questionsthere_paper1,i = ds_difficult.getItemdecimal(1,compute_+trim(string(i)nextfor i = 1 to var_questionsthere_paper2,i = ds_difficult.getItemdecimal(1,compute_+trim(string(i+10)nextds_difficult.dataObject = dw_analysis_end25ds_difficult.setTransObject(sqlca)ds_difficul

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

当前位置:首页 > 办公文档 > 其他范文


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号