在大型数据库系统中存储过程和触发器具有很重要的作用无论是存储过程还是触发器都是SQL 语句和流程控制语句的集合就本质而言触发器也是一种存储过程存储过程在运算时生成执行方式所以以后对其再运行时其执行速度很快SQL Server 2000 不仅提供了用户自定义存储过程的功能而且也提供了许多可作为工具使用的系统存储过程。
1 存储过程概述
1.1 存储过程的概念
存储过程Stored Procedure是一组为了完成特定功能的SQL语句集经编译后存储在数据库中用户通过指定存储过程的名字并给出参数如果该存储过程带有参数来执行它
在SQL Server的系列版本中存储过程分为两类系统提供的存储过程和用户自定义
存储过程系统过程主要存储在master数据库中并以sp_为前缀并且系统存储过程主
要是从系统表中获取信息从而为系统管理员管理SQL Server提供支持通过系统存储
过程MS SQL Server中的许多管理性或信息性的活动如了解数据库对象数据库信息
都可以被顺利有效地完成尽管这些系统存储过程被放在master数据库中但是仍可以
在其它数据库中对其进行调用在调用时不必在存储过程名前加上数据库名而且当创建
一个新数据库时一些系统存储过程会在新数据库中被自动创建用户自定义存储过程是
由用户创建并能完成某一特定功能如查询用户所需数据信息的存储过程在本章中所
涉及到的存储过程主要是指用户自定义存储过程
1.2 存储过程的优点
当利用MS SQL Server 创建一个应用程序时Transaction-SQL 是一种主要的编程语
言若运用Transaction-SQL 来进行编程有两种方法其一是在本地存储Transaction-
SQL 程序并创建应用程序向SQL Server 发送命令来对结果进行处理其二是可以把
部分用Transaction-SQL 编写的程序作为存储过程存储在SQL Server 中并创建应用程序
来调用存储过程对数据结果进行处理存储过程能够通过接收参数向调用者返回结果集
结果集的格式由调用者确定返回状态值给调用者指明调用是成功或是失败包括针对
数据库的操作语句并且可以在一个存储过程中调用另一存储过程
我们通常更偏爱于使用第二种方法即在SQL Server 中使用存储过程而不是在客户
计算机上调用Transaction-SQL 编写的一段程序原因在于存储过程具有以下优点
1 存储过程允许标准组件式编程
存储过程在被创建以后可以在程序中被多次调用而不必重新编写该存储过程的SQL
语句而且数据库专业人员可随时对存储过程进行修改但对应用程序源代码毫无影响因
为应用程序源代码只包含存储过程的调用语句从而极大地提高了程序的可移植性
2 存储过程能够实现较快的执行速度
如果某一操作包含大量的Transaction-SQL 代码或分别被多次执行那么存储过程要
比批处理的执行速度快很多因为存储过程是预编译的在首次运行一个存储过程时查
询优化器对其进行分析优化并给出最终被存在系统表中的执行计划而批处理的Transaction-
SQL 语句在每次运行时都要进行编译和优化因此速度相对要慢一些
3 存储过程能够减少网络流量
对于同一个针对数据数据库对象的操作如查询修改如果这一操作所涉及到的
Transaction-SQL 语句被组织成一存储过程那么当在客户计算机上调用该存储过程时
网络中传送的只是该调用语句否则将是多条SQL 语句从而大大增加了网络流量降
低网络负载
4 存储过程可被作为一种安全机制来充分利用
系统管理员通过对执行某一存储过程的权限进行限制从而能够实现对相应的数据访
问权限的限制避免非授权用户对数据的访问保证数据的安全
存储过程虽然既有参数又有返回值但是它与函数不同存储过程的返回值只是指明执行
是否成功并且它不能像函数那样被直接调用也就是在调用存储过程时在存储过程名
1 存储过程概述
1.1 存储过程的概念
存储过程Stored Procedure是一组为了完成特定功能的SQL语句集经编译后存储在数据库中用户通过指定存储过程的名字并给出参数如果该存储过程带有参数来执行它
在SQL Server的系列版本中存储过程分为两类系统提供的存储过程和用户自定义
存储过程系统过程主要存储在master数据库中并以sp_为前缀并且系统存储过程主
要是从系统表中获取信息从而为系统管理员管理SQL Server提供支持通过系统存储
过程MS SQL Server中的许多管理性或信息性的活动如了解数据库对象数据库信息
都可以被顺利有效地完成尽管这些系统存储过程被放在master数据库中但是仍可以
在其它数据库中对其进行调用在调用时不必在存储过程名前加上数据库名而且当创建
一个新数据库时一些系统存储过程会在新数据库中被自动创建用户自定义存储过程是
由用户创建并能完成某一特定功能如查询用户所需数据信息的存储过程在本章中所
涉及到的存储过程主要是指用户自定义存储过程
1.2 存储过程的优点
当利用MS SQL Server 创建一个应用程序时Transaction-SQL 是一种主要的编程语
言若运用Transaction-SQL 来进行编程有两种方法其一是在本地存储Transaction-
SQL 程序并创建应用程序向SQL Server 发送命令来对结果进行处理其二是可以把
部分用Transaction-SQL 编写的程序作为存储过程存储在SQL Server 中并创建应用程序
来调用存储过程对数据结果进行处理存储过程能够通过接收参数向调用者返回结果集
结果集的格式由调用者确定返回状态值给调用者指明调用是成功或是失败包括针对
数据库的操作语句并且可以在一个存储过程中调用另一存储过程
我们通常更偏爱于使用第二种方法即在SQL Server 中使用存储过程而不是在客户
计算机上调用Transaction-SQL 编写的一段程序原因在于存储过程具有以下优点
1 存储过程允许标准组件式编程
存储过程在被创建以后可以在程序中被多次调用而不必重新编写该存储过程的SQL
语句而且数据库专业人员可随时对存储过程进行修改但对应用程序源代码毫无影响因
为应用程序源代码只包含存储过程的调用语句从而极大地提高了程序的可移植性
2 存储过程能够实现较快的执行速度
如果某一操作包含大量的Transaction-SQL 代码或分别被多次执行那么存储过程要
比批处理的执行速度快很多因为存储过程是预编译的在首次运行一个存储过程时查
询优化器对其进行分析优化并给出最终被存在系统表中的执行计划而批处理的Transaction-
SQL 语句在每次运行时都要进行编译和优化因此速度相对要慢一些
3 存储过程能够减少网络流量
对于同一个针对数据数据库对象的操作如查询修改如果这一操作所涉及到的
Transaction-SQL 语句被组织成一存储过程那么当在客户计算机上调用该存储过程时
网络中传送的只是该调用语句否则将是多条SQL 语句从而大大增加了网络流量降
低网络负载
4 存储过程可被作为一种安全机制来充分利用
系统管理员通过对执行某一存储过程的权限进行限制从而能够实现对相应的数据访
问权限的限制避免非授权用户对数据的访问保证数据的安全
存储过程虽然既有参数又有返回值但是它与函数不同存储过程的返回值只是指明执行
是否成功并且它不能像函数那样被直接调用也就是在调用存储过程时在存储过程名