[高等教育]chapter 4 Store Procedure and Trigger.pptVIP

[高等教育]chapter 4 Store Procedure and Trigger.ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
[高等教育]chapter 4 Store Procedure and Trigger

Chapter 4 存储过程与触发器 任课教师:张艳 Email: zy_helen@ ftp: 0 , zy_helen_std 存储过程 概述 存储过程就是作为可执行对象存放在数据库中的一个或多个SQL命令。存储过程可以交互式调用,可以在客户端应用程序代码中调用,在另一存储过程中调用或在触发器中调用。 存储过程可以传入参数和返回数值,从而增加可用性和灵活性。 存储过程还可以返回多个结果集和状态码 存储过程的优点 模块化编程—正如C、C++中常使用函数和子例程将代码分解成更小的块一样,使用存储过程可以得到同样的好处,只是存储过程存放在SQL Server中,可以在任何客户端应用程序代码中调用。 存储过程 存储过程的优点 基于函数限制访问表格—可以访问执行存储过程而不必拥有直接操作基础表的权限 减少网络通信流—存储过程可以包含多条SQL语句,但只要用一条语句来执行该存储过程,从而减少了客户端应用程序对服务器的调用次数和长度 快速执行—首次执行后,存储过程查询计划保存在内存中,后续执行时不再需要分析和优化代码 保证一致性—如果用户只通过存储过程修改数据,则可以消除偶然修改带来的问题 减少操作人员和编程人员的错误—由于传递信息少,因此执行复杂任务更容易,不易出现SQL错误 存储过程 存储过程的缺点(取决于环境) 编程语言功能差—T-SQL语言不是很强大的或高度结构化的语言 与编程环境集成不够—许多大型软件开发项目用工具进行版本处理、调试、复用等,这些工具可能不支持存储过程中的代码 移植性差—ANSI标准和SQL Server标准存在差异,许多DBMS厂家不支持新标准,导致存储过程移植性差 存储过程 生成与执行存储过程 格式: create proc [owner.] procedure_name [ ; number] [[([@parm_name datatype=default_value [output] [,…][)]] [with { recompile | encryption}] As SQL statements [return {integer_status_value]] 总是用RETURN语句指定存储过程结束和遇到错误条件时指定非0状态是一个好的编程习惯 存储过程 生成与执行存储过程 例1:生成返回书名与作者名的存储过程 Create Proc dbo.title_authors AS Select a.au_lname, a.au_fname, t.title From titles t Inner Join titleauthor ta On t.title_id=ta.title_id Right Outer Join authors a On ta.au_id=a.au_id Return 该存储过程中的查询涉及到三张表:titles、titleauthor和authors。t是表titles的别名、a是表authors的别名、ta是表titleauthor的别名。 存储过程 生成与执行存储过程 执行存储过程:要执行存储过程,只要调用过程名即可。 如果过程不是批命令中的第一条语句,则要在过程名前面加上关键字EXEC。这是因为存储过程名不是关键字,当语句在执行过程中遇到存储过程名时,会将其作为上一条语句的一部分处理,因此导致执行出错。 例2:执行存储过程title_authors: title_authors Select * from titles title_authors Select * from titles exec title_authors 存储过程 存储过程组 如果生成的存储过程在数据库中已经存在,则会收到错误信息。但SQL Server提供了相应的解决办法,它允许生成多个同名的存储过程,只要组号不同。默认组号为1。 要生成不同组号的存储过程,只要加上分号(;)和一个整数 例3:生成查询国籍为’CA’的作者名与书名的存储过程 Create Proc dbo.title_authors; 2 AS Select a.au_lname, a.au_fname, state, t.title From titles t Inner Join titleauthor ta On t.title_id=ta.title_id Right Outer Join authors a On ta.au_id=a.au_id Where a.state=‘CA’ Return 存储过程 删除存储过程 格式: Drop Proc Procedure_name 例如:删除存储过程title_authors Drop proc

文档评论(0)

ctuorn0371 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档