文档详情

SQL存储过程入门教程.doc

发布:2025-06-12约2.6万字共28页下载文档
文本预览下载声明

1.sql存储过程概述

在大型数据库系统中,存储过程和触发器具有很重要的作用。无论是存储过程还是触发器,都是SQL语句和流程控制语句的集合。就本质而言,触发器也是一种存储过程。存储过程在运算时生成执行方式,所以,以后对其再运行时其执行速度很快。SQLServer2000不仅提供了用户自定义存储过程的功能,而且也提供了许多可作为工具使用的系统存储过程。

1.1存储过程的概念

存储过程〔StoredProcedure〕是一组为了完成特定功能的SQL语句集,经编译后存储在数据库。中用户通过指定存储过程的名字并给出参数〔如果该存储过程带有参数〕来执行它。

在SQLServer的系列版本中存储过程分为两类:系统提供的存储过程和用户自定义存储过程。系统过程主要存储在master数据库中并以sp_为前缀,并且系统存储过程主要是从系统表中获取信息,从而为系统管理员管理SQLServer提供支持。通过系统存储过程,MSSQLServer中的许多管理性或信息性的活动〔如了解数据库对象、数据库信息〕都可以被顺利有效地完成。尽管这些系统存储过程被放在master数据库中,但是仍可以在其它数据库中对其进行调用,在调用时不必在存储过程名前加上数据库名。而且当创立一个新数据库时,一些系统存储过程会在新数据库中被自动创立。用户自定义存储过程是由用户创立并能完成某一特定功能〔如查询用户所需数据信息〕的存储过程。在本章中所涉及到的存储过程主要是指用户自定义存储过程。

1.2存储过程的优点

当利用MSSQLServer创立一个应用程序时,Transaction-SQL是一种主要的编程语言。假设运用Transaction-SQL来进行编程,有两种方法。其一是,在本地存储Transaction-SQL程序,并创立应用程序向SQLServer发送命令来对结果进行处理。其二是,可以把局部用Transaction-SQL编写的程序作为存储过程存储在SQLServer中,并创立应用程序来调用存储过程,对数据结果进行处理存储过程能够通过接收参数向调用者返回结果集,结果集的格式由调用者确定;返回状态值给调用者,指明调用是成功或是失败;包括针对数据库的操作语句,并且可以在一个存储过程中调用另一存储过程。

我们通常更偏爱于使用第二种方法,即在SQLServer中使用存储过程而不是在客户计算机上调用Transaction-SQL编写的一段程序,原因在于存储过程具有以下优点:

〔1〕存储过程允许标准组件式编程

存储过程在被创立以后可以在程序中被屡次调用,而不必重新编写该存储过程的SQL语句。而且数据库专业人员可随时对存储过程进行修改,但对应用程序源代码毫无影响〔因为应用程序源代码只包含存储过程的调用语句〕,从而极大地提高了程序的可移植性。

〔2〕存储过程能够实现较快的执行速度

如果某一操作包含大量的Transaction-SQL代码或分别被屡次执行,那么存储过程要比批处理的执行速度快很多。因为存储过程是预编译的,在首次运行一个存储过程时,查询优化器对其进行分析、优化,并给出最终被存在系统表中的执行方案。而批处理的Transaction-SQL语句在每次运行时都要进行编译和优化,因此速度相对要慢一些。

〔3〕存储过程能够减少网络流量

对于同一个针对数据数据库对象的操作〔如查询、修改〕,如果这一操作所涉及到的Transaction-SQL语句被组织成一存储过程,那么当在客户计算机上调用该存储过程时,网络中传送的只是该调用语句,否那么将是多条SQL语句,从而大大增加了网络流量,降低网络负载。

〔4〕存储过程可被作为一种平安机制来充分利用

系统管理员通过对执行某一存储过程的权限进行限制,从而能够实现对相应的数据访问权限的限制,防止非授权用户对数据的访问,保证数据的平安。〔我们将在14章“SQLServer的用户和平安性管理”中对存储过程的这一应用作更为清晰的介绍〕

注意:存储过程虽然既有参数又有返回值,但是它与函数不同。存储过程的返回值只是指明执行是否成功,并且它不能像函数那样被直接调用,也就是在调用存储过程时,在存储过程名字前一定要有EXEC保存字。

2.SQL存储过程创立

创立存储过程,存储过程是保存起来的可以接受和返回用户提供的参数的Transact-SQL语句的集合。

可以创立一个过程供永久使用,或在一个会话中临时使用〔局部临时过程〕,或在所有会话中临时使用〔全局临时过程〕。

也可以创立在Microsoft?SQLServer?启动时自动运行的存储过程。

2.1语法

CREATEPROC[EDURE]procedure_name[;number]

[{@parameterda

显示全部
相似文档