当前位置:首页 > 嵌入式 > 嵌入式硬件

摘 要: 利用SQL Server作为数据库管理平台开发高校通用计算机在线考试软件系统时,由于数据量较大,最应关注的是软件系统的运行速度、性能和可维护性等指标。如果采用常规的程序设计方案,会造成网络通信数据量大、业务逻辑处理速度慢、系统运行效率低等问题。为解决这些问题,软件系统中相关业务逻辑设计采用存储过程的方法实现,大大减少了网络流量,提高了系统的性能和可维护性。
关键词: SQL Server; 在线考试; 网络流量; 存储过程

随着计算机网络技术和数据库技术的飞速发展,高校的数字化校园建设进程日益深入,其中数字化教学与学习环境建设成为其核心内容。为推动数字化校园建设进程,创建数字化教学环境,利用Delphi7和SQL Server2000开发出适用于多学科的高校通用计算机在线考试软件系统。Delphi在基于C/S模式的数据库应用开发领域具有很强的数据库支持能力,因为它提供了丰富的数据库操作组件,常用的有TQuery、TTable、TADOQuery和TADOTable等[1]。通过这些组件,程序员可以在短时间内完成一个应用程序模块的设计,大大减少了开发人员的工作量。但是,这些组件在操作数据库时却存在局限性,即必须将数据库中的记录从服务器端取出放入到客户端,再根据查询条件进行选择。这种实现方法,如果待访问的数据量较大,势必因为查询时间较长而降低程序执行的速度,从而降低应用程序的性能。解决这一问题利用了SQL Server2000的存储过程来实现[2]。
1 存储过程及其优点
1.1 存储过程的定义
存储过程是存储在服务器上的一组预先定义并编译好的用来实现某种特定功能的SQL语句。它可以接受参数、返回状态值或参数值。存储过程在服务器端执行,通过应用程序调用的方法实现,执行结束后再把结果返回到客户端。
1.2 存储过程的优点
(1)存储过程执行速度快,便于提高系统的性能。由于存储过程在第一次执行之后,其执行规划就储存在高速缓冲存储区中,在以后的操作中。只需从高速缓冲存储区中调用编译好的二进制形式存储过程来执行[3]。
(2)减少网络流量,提高系统执行效率。客户端应用程序调用一个存储过程,只需通过网络发送该过程名和少量入口参数,数据库服务器就可执行该过程,执行完成后,只返回结果状态或将最终结果集给客户端应用程序,无需通过网络传送大量的SQL操作命令和中间结果,最大限度地减少网络通信负担,提高了执行效率。
(3)维护了数据库的安全性。如果用户被授予执行存储过程的权限,即使该用户没有在执行该存储过程中可参考的表或视图的访问权限,该用户也可以完全执行该存储过程而不受影响。因此,可以通过创建存储过程来完成数据的插入、更新和删除等操作,并且可以通过编程方式控制在操作中对信息的访问权限[4]。
(4)提高软件系统的可维护性。存储过程在创建时就在服务器上经过调试和编译,可以避免不必要的错误出现。另外,存储过程将相关业务逻辑封装在一起,可以大大提高整个软件系统的可维护性。因为当相关业务逻辑发生变化时,不需要修改并编译客户端应用程序,只需要修改位于服务器端的实现相应业务逻辑的存储过程即可。
(5)充分增强SQL语言的功能和灵活性。存储过程可以用流控制语句编写,有很强的灵活性,可以完成复杂的判断和运算。
基于以上优点,在进行C/S模式数据库应用系统开发时,通常把比较浪费时间、影响网络传送的相关业务逻辑编写成存储过程由服务器执行,同时利用服务器的SQL语法进行优化处理,只将少量的结果显示在客户端,充分提高软件系统的性能[5]。
2 存储过程的创建方法
以SQL Server 2000数据库管理系统为背景,创建方法如下:
CREATE PROC[EDURE]
procedure_name[;number]
[{@parameter data_type}[VARYING][=default] [OUTPUT] ][,...n]
[WITH {RECOMPILE | ENCRYPTION | RECOMPILE, ENCRYPTION}]
[FOR REPLICATION]
AS sql_statement [...n ]
下面对语法中各选项进行说明:
(1)选项“procedure_name”指存储过程名,不能超过128个字符,“[;number]”指程序编号,用于区别同名的存储过程。
(2)选项“@parameter”表示参数,每个存储过程中最多可以设定1 024个参数,要求在每个参数名前加上符号“@”。
(3)选项“[=default]”指为对应参数设定默认值。
(4)选项“OUTPUT”用来指定参数既有输入又有输出。即在调用这个存储过程时,如果所指定的参数是要输入的参数,同时也需要在结果中输出,则该项必须为“OUTPUT”。
(5)选项“WITH”用来指定存储过程的处理方式。
(6)选项“FOR REPLICATION”表示只能由复制方式执行[6]。
3 存储过程在考试软件系统中的应用
(1)考试系统在运行时要经过三个步骤,考生抽取套题编号、抽取套题内容和将套题内容插入答题表进行答题。如果不采用存储过程,则需用下面方法实现。
①随机抽取套题编号
select 套题编号from tblcrecord order by newid()
②抽取对应套题内容,套题编号存储在dm.strNum中
with qry1 do
Begin
Close ;
SQL.Clear ;
SQL.Add(′Select * from tblTK Where 套题编号
='''+dm.strNum +''');
Open ;
End;
③插入考试题到考试表tblKS中
qry1.First;
While not qry1.Eof Do
begin
qry2.Append;
qry2.FieldByName(‘考生学号’).Value:= qry1.Field-
ByName(‘考生学号’).Value;

qry2.Post;
end;
显然,此种方法步骤繁琐,耗时较多,在考试过程中会产生抽题缓慢的现象,系统性能严重降低。为避免此种情况的发生,考试系统采用了存储过程的方法,代码如下[7]:
CREATE PROCEDURE cp_Paper_Add
@MyNo char(10),
@Mynum char(20)
AS
set nocount on
exec(′insert into tblKS (学生学号、套题编号、试题序号、试题内容、试题答案、试题分数、是否答题、套题名称、考试科目、试题类型、学生分数、类别序号) select''''+@MyNo+'''',''''+@Mynum+''',试题序号,试题内容,试题答案,试题分数,“否”,套题名称,科目名称,试题类型,0,类别序号 from tblTK where 套题编号='''+@Mynum+''' )
GO
通过执行存储过程,将题库中与考生抽取套题编号相匹配的记录提取出来,并批量插入到考试表中,同时对考生分数进行了初始化为0的动作。而本考试系统就是将考生的学号和考生抽取的套题编号作为参数传递给存储过程,因此,大幅度提高了考试软件的效率。
(2)在考试系统进行不同类型题目抽取时,如果在Delphi中直接应用SQL语句,应使用下面代码:
with cds1 do
Begin
Close ;
SQL.Clear ;
SQL.Add(′Select * from tblKS Where 学生学号=′);
SQL.Add(‘ ?苁+dm.strNo +?苁 and 试题类型=′′单项选择题′′ order by 试题序号′);
Open ;
End;
此时,程序是在运行时才编译的。这样就增加了运行的时间,同时还要把完整的SQL语句传递给Sql Server服务器执行,这样考试过程中势必增加网络流量,降低软件的运行效率。
如果采用存储过程,可用下面方法实现:
CREATE PROCEDURE sp_Query_All
@strNo char(10)
AS
set nocount on
Select Select * from tblKS Where 学生学号=@strNO and 试题类型=′′单项选择题′′ order by 试题序号
GO
在客户端调用方法如下:
with cds1 do
Begin
Close ;
SQL.Clear ;
SQL.Add('exec sp_Query_All :strNO');

Params.ParamByName('strNO').Value:=DM.strNO;
  Open ;
  End;
此时,存储过程是预先编译的,自然节省了编译的时间,同时只向服务器传递了一个参数DM.strNO,大大减少了网络流量,提高了考试系统的性能。
(3)在考试系统中添加考生信息时,首先要判断是否存在该考生学号信息,然后再进行添加操作。如果采用普通SQL语句,代码如下:
with qry1 do
Begin
Close ;
SQL.Clear ;
SQL.Add(′select * from tblstudents where考生学号=
:strNO′);
Params.ParamByName('strNO').Value :=DM.strNO;
Open ;
if recordcount=0 then
begin
qry2.Append;
qry2.FieldByName(‘考生学号’).Value:= DM.strNO;

qry2.Post;
End;

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭