《SQLServer2005数据库技术及应用》课件第14章 存储过程和触发器

上传人:考试不挂****2941... 文档编号:243019645 上传时间:2024-09-14 格式:PPT 页数:14 大小:361.50KB
返回 下载 相关 举报
《SQLServer2005数据库技术及应用》课件第14章 存储过程和触发器_第1页
第1页 / 共14页
《SQLServer2005数据库技术及应用》课件第14章 存储过程和触发器_第2页
第2页 / 共14页
《SQLServer2005数据库技术及应用》课件第14章 存储过程和触发器_第3页
第3页 / 共14页
点击查看更多>>
资源描述
, , , , , ,*,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,
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 图纸专区 > 课件教案


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!