- 2
- 0
- 约2.5千字
- 约 14页
- 2018-06-27 发布于福建
- 举报
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触发器自动
您可能关注的文档
- La fabrication d’un petit véhicule制造一个小V与# 233 hicule;.doc
- Lab 1 - Homeostasis and Diffusion - UCF Burnett School of 实验1的平衡与扩散UCF的伯内特学院.docx
- Knowledge Representation 知识表示.ppt
- LA MAITRISE DES FLUX D’ÉNERGIE ET D’EAULa maitrise DES通量D’与# 201大nergie等;.doc
- Lab #2 Voltage and Current Division实验室# 2电压与电流分.doc
- Lab 3 Osmosis and Diffusion - Montana State University 实验3的渗透与扩散-蒙大拿州立大学.doc
- La tâche communicative langagière - the ECML的La T与# 226;车交际langagi与# 232;重新- ECML.ppt
- Lab M20 – Hooke’s Law and Simple Harmonic Motion实验室–M20胡克定律与简谐运动.doc
- KS4 Waves - Diffraction, Interference and ResonancepptKS4波衍射,干涉与resonanceppt.ppt
- Lab O4 Single and Multiple Slit Diffraction实验室O4单与多缝衍射.doc
原创力文档

文档评论(0)