SQLServer2005数据库技术及应用 第14章 存储过程与触发器.pptVIP

  • 2
  • 0
  • 约2.5千字
  • 约 14页
  • 2018-06-27 发布于福建
  • 举报

SQLServer2005数据库技术及应用 第14章 存储过程与触发器.ppt

SQLServer2005数据库技术及应用 第14章 存储过程与触发器

第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 PROC[EDURE] [owner.] procedure_name [ { @parameter data_type } [ =default ] [OUTPUT ] ] [ ,…n1 ] [ WITH { RECOMPILE | ENCRYPTION | RECOMPILE, ENCRYPTION }] AS sql_statement[ …n2 ] 14.2 用户存储过程的创建与执行 执行存储过程的语法格式: [ EXEC[UTE] ] { [@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触发器自动

您可能关注的文档

文档评论(0)

1亿VIP精品文档

相关文档