起步于系统工程师,迈进入测试工程师,从起初的C/S系统到互联网时代的B/S系统,从事过电信增值业务、软交换、烟草OA、公安技侦和电子商务等行业的软件测试开发和管理多年,愿与大家共同分享共同交流,关注软件项目管理、测试团队管理、软件流程控制和软件性能测试及自动化测试技术。互联网时代,技术推动进步,欢迎人才推荐:jonas.wangl@alibaba-inc.com

SQL中存储过程的作用是什么

上一篇 / 下一篇  2009-11-18 17:51:55 / 个人分类:数据库

51Testing软件测试网|/Q1^A'_ }/o$O(f{

  很多QA在测试数据库的存储过程案例,常常会问存储过程到底是干嘛用的,有什么作用呢,我结合一些资料整理了下,可做为一个参考,欢迎发表意见和建议。 51Testing软件测试网&x Y T N SR(dB$L d

d#A,B+t/dR0I!M'a0  我们通常说存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库。用户通过指定存储过程的名字并给出参数来执行它。51Testing软件测试网7`5w.Ml,^@"R Tan ~
51Testing软件测试网 B D+h;Sb"SQD U
  在SQL Server 的系列版本中存储过程分为两类:系统提供的存储过程和用户自定义存储过程。系统过程主要存储在master 数据库中并以sp_为前缀,并且系统存储过程主要是从系统表中获取信息,从而为系统管理员管理SQL Server 提供支持。通过系统存储过程,MS SQL Server 中的许多管理性或信息性的活动(如了解数据库对象、数据库信息)都可以被顺利有效地完成。尽管这些系统存储过程被放在master 数据库中,但是仍可以在其它数据库中对其进行调用,在调用时不必在存储过程名前加上数据库名。而且当创建一个新数据库时,一些系统存储过程会在新数据库中被自动创建。用户自定义存储过程是由用户创建并能完成某一特定功能(如查询用户所需数据信息)的存储过程。在本章中所涉及到的存储过程主要是指用户自定义存储过程。51Testing软件测试网lqYQHeM(I"B0H

!F;Ah'\&G V0 那么存储过程的优点有哪些呢?
,X^9\ T2{R4H0
B]9~k x0 当利用MS SQL Server 创建一个应用程序时,Transaction-SQL 是一种主要的编程语言。若运用Transaction-SQL 来进行编程,有两种方法。其一是,在本地存储Transaction- SQL 程序,并创建应用程序向SQL Server 发送命令来对结果进行处理。其二是,可以把部分用Transaction-SQL 编写的程序作为存储过程存储在SQL Server 中,并创建应用程序来调用存储过程,对数据结果进行处理存储过程能够通过接收参数向调用者返回结果集,结果集的格式由调用者确定;返回状态值给调用者,指明调用是成功或是失败;包括针对数据库的操作语句,并且可以在一个存储过程中调用另一存储过程。51Testing软件测试网;G wB KjsE

TFy:pQR^0  我们通常更偏爱于使用第二种方法,即在SQL Server 中使用存储过程而不是在客户计算机上调用Transaction-SQL 编写的一段程序,原因在于存储过程具有以下优点:
&M-t'O uiv,|6m051Testing软件测试网2r9Tv7z0JF
   存储过程允许标准组件式编程
l R J]t z V*j051Testing软件测试网)rs7[%hhH-p'^
  存储过程在被创建以后可以在程序中被多次调用,而不必重新编写该存储过程的SQL 语句。而且数据库专业人员可随时对存储过程进行修改,但对应用程序源代码毫无影响(因为应用程序源代码只包含存储过程的调用语句),从而极大地提高了程序的可移植性。

1n](k!a_]8Mc0

TAG:

 

评分:0

我来说两句

Open Toolbar