利用利用SQL Server存储过程提高在线考试系统的性能存储过程提高在线考试系统的性能
利用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;