- 1、本文档共43页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
SQL Server 2008数据库开发经典案例教程 习题解答等-吕玉桂 第13章存储过程新
PPT研究院 POWERPOINT ACADEMY * 讲解要点: 由修建茅屋和大厦的对比,得出结论:当数据库比较复杂(如数据量大,表较多,业务关系复杂)时, 我们需要先创建数据库; * * * * * 第13章 存储过程 本章目标 了解存储过程的优点 掌握常用的系统存储过程 掌握如何创建存储过程 掌握如何调用存储过程 存储过程介绍 存储过程是在数据库管理系统中保存的,预先编译的并能实现某种功能的SQL程序。 存储过程相当于编程语言(如JAVA等)中的方法,就是由SQL语句和控制语句组成的能够完成特定某个功能的预编译语句的集合。存储过程是保存在数据库服务器中的,可以直接在SQLServer客户端中调用也可以通过程序语言调用. 存储过程的优点 存储过程的优点: 允许模块化程序设计 只需创建过程一次并将其存储在数据库中,以后即可在程序中调用该过程任意次 允许更快执行 存储过程将比Transact-SQL批代码的执行要快 减少网络流量 存储过程存储在后端数据库中不需要通过网络传输 可作为安全机制使用 即使对于没有直接执行存储过程中语句权限的用户,也可授予他执行该存储过程的权限 存储过程中的语句 存储过程 -------- -------- 单个 SELECT 语句 SELECT 语句块 可以包含 SELECT语句与逻辑控制语句 存储过程中的语句 SQL Server中的存储过程与其他语言中的过程或函数类似,它们的共同特征是 : 它们都接收输入参数,并向调用过程或语句返回值。 它们都包含在数据库中执行操作或调用其他存储过程的编程语句。 它们都向调用过程返回状态值,指示执行过程是否成功 常用的系统存储过程 SQL Server提供系统存储过程,它们是一组预编译的T-SQL语句 所有系统存储过程的名称都以“_sp”开头。系统存储过程位于master数据库中 系统存储过程 说 明 sp_databases 列出服务器上的所有数据库 sp_helpdb 报告有关指定数据库或所有数据库的信息 sp_renamedb 更改数据库的名称 sp_tables 返回当前环境下可查询的对象的列表 sp_columns 返回某个表列的信息 sp_help 查看某个表的所有信息 sp_helpconstraint 查看某个表的约束 sp_helpindex 查看某个表的索引 sp_stored_procedures 列出当前环境中的所有存储过程 sp_helptext 显示默认值、未加密的存储过程、用户定义的存储过程、触发器或视图的实际文本 常用的系统存储过程的使用 EXEC sp_server_info --返回服务器信息 EXEC sp_databases --返回服务器数据库信息 EXEC sp_who --返回当前登录用户信息和进程信息 EXEC sp_tables --返回表信息 EXEC sp_helpdb --返回特定数据库信息 示例:其他系统存储过程的使用 一些系统存储过程必须在特定的数据库中使用,大多数在所有数据库中可用 创建存储过程 创建存储过程 SSMS:可视化的方式 T-SQL:代码 使用CREATE PROCEDURE语句创建存储过程。所有的存储过程都创建在当前数据库中 语法: CREATE PROC[EDURE] 存储过程名 [ {@参数1 数据类型} [=默认值] [OUTPUT], ......., {@参数n 数据类型} [=默认值] [OUTPUT] ] AS SQL语句 其中,参数部分为可选 创建简单的存储过程 --使用存储过程返回所有的书籍信息 USE BookShop GO --判断存储过程select_books是否存在 IF OBJECT_ID ( SELECT_books, P ) IS NOT NULL DROP PROCEDURE SELECT_books; GO --创建存储过程 CREATE PROCEDURE SELECT_books AS SELECT Id,Title,Author,PublishDate, UnitPrice,ISBN FROM books GO 调用存储过程 语法: 调用示例存储过程 EXEC 过程名 [ 参数] EXECUTE SELECT_books 创建带参数的存储过程 CREATE PROC[EDURE] 存储过程名 [ {@参数1 数据类型} [=默认值] [OUTPUT], .....
文档评论(0)