资源描述
, , , , , ,*,SQL Server 2005,第,14,章 存储过程和触发器,第,14,章 存储过程和触发器,14.1,存储过程的基本概念,14.2,用户存储过程的创建与执行,14.3,用户存储过程的修改,14.4,用户存储过程的删除,14.5,触发器,14.5.1,利用,SQL,命令创建触发器,14.5.2,触发器的修改,14.5.3,触发器的删除,14.1,存储过程的基本概念,存储过程是一组为了完成特定功能的,T-SQL,语句集合,有些类似上一章提到的用户自定义函数,所不同的是存储过程的语句存储在,SQL Server,服务器端数据库中,而不是存储在客户计算机上,并且在使用前经过了编译处理,设计存储过程的主要目的是提高数据检索速度,而且存储过程具有传递参数和执行逻辑表达式的功能,使用它有助于在,SQL Server,中处理比较复杂的任务,存储过程分类,系统存储过程,是,SQL Server,安装好后系统自动提供的存储过程,可以作为命令执行各种操作,用户自定义存储过程,是指用户在数据库中自己创建的存储过程,扩展存储过程,在,SQL Server,环境之外通过对动态链接库(,DLL,)的调用执行的存储过程被称为扩展存储过程,14.2,用户存储过程的创建与执行,创建存储过程的语法格式:,CREATE PROCEDURE owner.,procedure_name, parameter,data_type, =default OUTPUT , ,n1 , WITH RECOMPILE | ENCRYPTION | RECOMPILE, ENCRYPTION ,AS,sql_statement,n2 ,14.2,用户存储过程的创建与执行,执行存储过程的语法格式:, EXECUTE ,return_status,=,procedure_name,| ,procedure_name_var, parameter= value | variable OUTPUT | DEFAULT ,n,WITH RECOMPILE,14.3,用户存储过程的修改,语法格式:,ALTER PROC EDURE ,procedure_name, parameter,data_type, VARYING =default OUTPUT , ,n1 , WITH RECOMPILE|ENCRYPTION|RECOMPILE, ENCRYPTION , FOR REPLICATION ,AS,sql_statement,n2 ,14.4,用户存储过程的删除,当不再使用一个存储过程时,就要把它从数据库中删除。使用,DROP PROCEDURE,语句可永久地删除存储过程。,语法格式:,DROP PROCEDURE procedure ,n,14.5,触发器,触发器可以看作一类特殊的存储过程,与一般存储过程不同的就是它不是由用户直接调用执行的,而是事先设好触发条件,满足条件时触发器就会自动执行。,触发器的主要作用是保护表中的数据,当对表的操作影响到触发器保护的数据时,触发器自动执行。,一般情况下,对表数据的操作有:插入、修改、删除,因而维护数据的触发器也可分为三种类型:,INSERT, UPDATE,和,DELETE,。,使用触发器的主要目的是实现比较复杂的数据完整性,14.5.1,利用,SQL,命令创建触发器,一般语法格式:,CREATE TRIGGER,trigger_name,ON ,table|view, WITH ENCRYPTION ,FOR INSERT,,,DELETE,,,UPDATE,AS,sql_statement,n,触发器中使用的特殊表,执行触发器时,,SQL Server,统会自动创建两个特殊的表:,inserted,表和,deleted,表,它们是临时的逻辑表,由系统维护,不允许用户直接对它们进行修改。这两个临时逻辑表存放在计算机内存中而不是数据库里,所以触发器工作完成后即被删除,触发器中使用的特殊表,inserted,逻辑表:当用户向表中插入数据时,,INSERT,触发器触发自动执行,新记录不仅插入到要求的实际表中,而且还同样插入到,inserted,表中,也就是说实际上新数据在内存中还有一个副本。,deleted,逻辑表:用于保存已从表中删除的记录,亦即:当用户从表中删除一些记录时,,DELETE,触发器自动执行,要删除的记录在实际表中消失,内存中的临时逻辑表,deleted,中则添加一个和别删除记录相同的的记录。,如果用户对表中数据进行更新,系统的理解是:修改一条记录等于插入一条新记录,同时删除旧记录。当对定义了,UPDATE,触发器的表记录修改时,表中原记录移到,deleted,表中,修改过的记录插入到,inserted,表中。,deleted,表和,inserted,表的结构总是与被该触发器作用的表的结构相同,注意这两个特殊表不能被其他过程引用,这能由创建它们的触发器引用。,对,deleted, inserted,逻辑表的查询方法与一般数据库表的查询方法相同,14.5.2,触发器的修改,语法格式:,ALTER TRIGGER,trigger_name,ON ,table|view, WITH ENCRYPTION ,FOR INSERT,,,DELETE,,,UPDATE,AS,sql_statement,n,14.5.3,触发器的删除,语法格式:,DROP TRIGGER ,trigger_name, ,n,
展开阅读全文