- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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
您可能关注的文档
- [高二英语]Grammar外研选修8 module3.ppt
- [高二英语]book7unit4sharingReading.ppt
- [高二英语]M5U2Reading1.ppt
- [高二英语]Reading and vocabulary.ppt
- [高二英语]Unit 15 lesson 3 Teachers 教学课件.ppt
- [高二英语]Task Writing a literary review.ppt
- [高二英语]unit 17 language study.ppt
- [高二英语]unit4 grammar名词性从句.ppt
- [高二英语]Unit_3_The_Government_of_the_United_Kingdom.ppt
- [高二英语]U3P1 Warming up.ppt
最近下载
- 2023年江苏省健康照护行业职业技能竞赛备考题库大全-下(判断题汇总).doc VIP
- 新22J01《工程做法》(新疆图集).pdf VIP
- 体检报告电子版.docx VIP
- 2024年8月17日国家综合性消防救援队伍消防员招录面试真题及答案解析(上午卷).doc VIP
- GA 1467-2018 城市轨道交通安全防范要求.docx VIP
- 羽毛球课程教学大纲.docx VIP
- 接正式电方案.pdf
- 2024年甘肃定西岷县城区部分学校竞聘教师实施(238人)笔试备考试题及答案解析.docx VIP
- DB11∕T 646.1-2016 城市轨道交通安全防范系统技术要求 第1部分:通则.docx VIP
- NIST SP 800-218 SSDF安全软件开发框架.xlsx
文档评论(0)