最新存储过程与触发器教学讲义PPT课件.ppt

最新存储过程与触发器教学讲义PPT课件.ppt

ID:62116720

大小:480.50 KB

页数:40页

时间:2021-04-17

最新存储过程与触发器教学讲义PPT课件.ppt_第1页
最新存储过程与触发器教学讲义PPT课件.ppt_第2页
最新存储过程与触发器教学讲义PPT课件.ppt_第3页
最新存储过程与触发器教学讲义PPT课件.ppt_第4页
最新存储过程与触发器教学讲义PPT课件.ppt_第5页
资源描述:

《最新存储过程与触发器教学讲义PPT课件.ppt》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、存储过程与触发器存储过程与触发器概述在大型数据库系统中,存储过程和触发器具有很重要的作用。无论是存储过程还是触发器,都是SQL语句和流程控制语句的集合。就本质而言,触发器也是一种存储过程。存储过程在运算时生成执行方式,所以,以后对其再运行时其执行速度很快。SQLServer2000不仅提供了用户自定义存储过程的功能,而且也提供了许多可作为工具使用的系统存储过程。1.1存储过程的概念存储过程(StoredProcedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中。用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。1.2存储过程的优点

2、(2)存储过程能够实现较快的执行速度如果某一操作包含大量的SQL代码或被多次执行,那么存储过程要比批处理的执行速度快很多。因为存储过程是预编译的,在首次运行一个存储过程时,查询优化器对其进行分析、优化,并给出最终被存在系统表中的执行计划。而批处理的SQL语句在每次运行时都要进行编译和优化,因此速度相对要慢一些。1.2存储过程的优点(3)存储过程能够减少网络流量对于同一个针对数据数据库对象的操作(如查询、修改),如果这一操作所涉及到的SQL语句被组织成一存储过程,那么当在客户计算机上调用该存储过程时,网络中传送的只是该调用语句,否则将是多条SQL语句,从而大大增加了网络流量,

3、降低网络负载。1.2存储过程的优点(4)存储过程可被作为一种安全机制来充分利用系统管理员通过对执行某一存储过程的权限进行限制,从而能够实现对相应的数据访问权限的限制,避免非授权用户对数据的访问,保证数据的安全。注意:存储过程虽然既有参数又有返回值,但是它与函数不同。存储过程的返回值只是指明执行是否成功,并且它不能像函数那样被直接调用,也就是在调用存储过程时,在存储过程名字前一定要有EXEC保留字存储过程几种写法1)创建使用参数的存储过程CreateProcau_info@lastnamevarchar(40),@firstnamevarchar(20)AsSelectau_

4、lname,au_fname,title,pub_nameFrom...whereau_fname=@firstnameAndau_lname=@lastnameGoEXECUTEau_inforinger,annecreateprocedures_query@namevarchar(255)asselectsno,sn,agefromswheresn=@namegoexecs_query‘李涛'存储过程几种写法2)创建使用参数默认值的存储过程,该存储过程在没有输入参数的情况下将默认值得到的结果输出CreateProcau_info@lastnamevarchar(40)=

5、'ringer',@firstnamevarchar(20)='anne'AsSelectau_lname,au_fname,title,pub_nameFrom...whereau_fname=@firstnameAndau_lname=@lastnameGoEXECUTEau_infocreateprocedures_query@namevarchar(255)=‘李涛’asselectsno,sn,agefromswheresn=@namegoexecs_query存储过程几种写法3)用显式值替代参数默认值的存储过程CreateProcshowind@tablevar

6、char(30)='titles'asSELECTTable_Name=sysobjects.name,INDEX_Name=sysindexes.name,index_id=indidfromsysindexesinnerjoinsysobjectsonsysobjects.id=sysindexes.idwheresysobjects.name=@tableEXECUTEshowindauthorscreateprocedures_query@namevarchar(255)=‘李涛’asselectsno,sn,agefromswheresn=@namegoexecs

7、_query‘陈文’存储过程几种写法4)使用参数默认值NULL来创建存储过程,在这种情况下如果没有提供参数值,SQL将不会出错显示CreateProcshowind@tablevarchar(30)=NullasIF@tableisNUllprint'请输入参数'elseSELECTTable_Name=sysobjects.name,INDEX_Name=sysindexes.name,index_id=indidfromsysindexsinnerjoinsysobjectsonsysobjects.id=sy

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。