oracle数据库资料
合集下载
相关主题
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
广西大学信息网络中心 卢豫开
计算机科学与技术专业
实例3:带有输入、输出参数的存储过程的创建与执行
Create proc hyproc3 @changkuhao varchar(50),@maxgz int output,@avggz
real output As Begin Select * from 职工 where 仓库号=@changkuhao Select @maxgz=max(工资) from 职工 where 仓库号
OrderID, CustomerID, EmployeeID FROM Orders WHERE EmployeeID = @Employee_ID and OrderDate = @Order_date GO
ቤተ መጻሕፍቲ ባይዱ
使用输入参数执行存储过程
计算机科学与技术专业
EX通EC过O参ver数du名eO传rd递ers值2 (@顺Em序pl无oy所ee_谓ID)= 1 ,
及失败原因) 以输出参数的形式将多个值返回至调用过程或批处理
存储过程的优点
计算机科学与技术专业
存储过程封装了商务逻辑,确保一致的数据访问和修改。若规则或 策略有变化,则只需要修改服务器上的存储过程,所有的客户端就 可以直接使用
屏蔽数据库模式的详细资料。用户不需要访问底层的数据库和数据 库内的对象
执行上下文
连接1
8082
连接2
24
连接3
1003
未用过的计划过时被清除
在存储过程中使用参数
使用输入参数 使用输入参数执行存储过程 使用输出参数返回值 显式地重新编译存储过程
计算机科学与技术专业
使用输入参数
计算机科学与技术专业
输入参数允许传递信息到存储过程内
在 CREATE PROCEDURE 中指定
存储过程的初始处理
计算机科学与技术专业
创建
执行
(初次或 重新编译)
解析 优化 编译
项存入 sysobjects 和 syscomments 表
编译过的执行计划 放入过程缓存
存储过程的后续处理
计算机科学与技术专业
若符合下列条件,则 SQL Server 使用在内存中的计划 来执行随后的查询
当前的环境和计划编译时的环境相同。服务器、数据库 和连接的设置决定了环境
计算机科学与技术专业
CREA输TE出P参RO数C:pr以oc1OUTPUT 关键字指定的变量
@A int , @B int , @RESULT int OUTPUT AS SET @RESULT = @A * @B GO
执行有输出参数的存储过程
DECLARE @answer int EXEC proc1 4, 7, @answer OUTPUT SELECT @answer as ANSWER
存储过程引用的对象不需要名称解析。若被不同用户拥 有的对象具有相同的名字,则需要名称解析。
一个执行计划产生后,驻留在过程缓存中。仅当需要空间 时,SQL Server 将老的、没用的计划移出缓存
存储过程的后续处理(续)
计算机科学与技术专业
检索到的执行计划 执行计划
SELECT * FROM dbo.member WHERE member_no = ?
USE Northw@ind参数名 数据类型 [=默认值]
GO CREATE PROC dbo.OverdueOrders2 @Employee_ID int , @Order_date datetime
AS SELECT CONVERT(char(8), OrderDate, 1) OrderDate,
=@changkuhao select @avggz=avg(工资) from 职工 where 仓库号
=@changkuhao end
广西大学信息网络中心 卢豫开
计算机科学与技术专业
实例3:带有输入、输出参数的存储过程的创建与执行
Declare @x1 int,@x2 real Execute hyproc3 'wh1',@x1 output,@x2
定义存储过程
计算机科学与技术专业
存储过程
是存储在服务器上的 Transact-SQL 语句的命名集合 是封装重复性任务的方法 支持用户声明变量、条件执行以及其他强有力的编程特性
SQL Server 中的存储过程与其他编程语言中的过程类似,它可以
包含执行数据库操作(包括调用其他过程)的编程语句 接受输入参数 向调用过程或批处理返回状态值,以表明成功或失败(以
output Select @x1 as wh1职工最大工资,@x2 as
@Order_date = '1996-7-17'
EXEC OverdueOrders2 @Order_date = '1996-7-17', @Employee_ID = 1
通过位置传递参数(顺序保持一致)
EXEC OverdueOrders2 1 , '1996-7-17'
使用输出参数返回值
储过程。
广西大学信息网络中心 卢豫开
计算机科学与技术专业
实例2:带有输入参数的存储过程的创建与执行
代码: Create proc hyproc2 @mingz int,@maxgz int as Select * from 职工 where 工资 between @mingz and
@maxgz 执行: Execute hyproc2 1500,2000
提供了安全性机制。用户可以被赋予执行存储过程的权限,而不必 在存储过程引用的所有对象上都有权限
改善性能。预编译的 Transact-SQL 语句,可以根据条件决定执 行哪一部分
减少网络通信量。客户端用一条语句调用存储过程,就可以完成可 能需要大量语句才能完成的任务,这样减少了客户端和服务器之间 的请求/回答包
必须定义一个变量, 以接受返回值
写上OUTPUT,才 可以接收到返回值
计算机科学与技术专业
实例1:不带参数的存储过程的创建与执行
输入代码: Create proc hyproc1 as Select * from 职工 where 工资 > 1800 执行代码: Execute hyproc1 在进行实验时请注意各数据库中的同名表和同名存
计算机科学与技术专业
实例3:带有输入、输出参数的存储过程的创建与执行
Create proc hyproc3 @changkuhao varchar(50),@maxgz int output,@avggz
real output As Begin Select * from 职工 where 仓库号=@changkuhao Select @maxgz=max(工资) from 职工 where 仓库号
OrderID, CustomerID, EmployeeID FROM Orders WHERE EmployeeID = @Employee_ID and OrderDate = @Order_date GO
ቤተ መጻሕፍቲ ባይዱ
使用输入参数执行存储过程
计算机科学与技术专业
EX通EC过O参ver数du名eO传rd递ers值2 (@顺Em序pl无oy所ee_谓ID)= 1 ,
及失败原因) 以输出参数的形式将多个值返回至调用过程或批处理
存储过程的优点
计算机科学与技术专业
存储过程封装了商务逻辑,确保一致的数据访问和修改。若规则或 策略有变化,则只需要修改服务器上的存储过程,所有的客户端就 可以直接使用
屏蔽数据库模式的详细资料。用户不需要访问底层的数据库和数据 库内的对象
执行上下文
连接1
8082
连接2
24
连接3
1003
未用过的计划过时被清除
在存储过程中使用参数
使用输入参数 使用输入参数执行存储过程 使用输出参数返回值 显式地重新编译存储过程
计算机科学与技术专业
使用输入参数
计算机科学与技术专业
输入参数允许传递信息到存储过程内
在 CREATE PROCEDURE 中指定
存储过程的初始处理
计算机科学与技术专业
创建
执行
(初次或 重新编译)
解析 优化 编译
项存入 sysobjects 和 syscomments 表
编译过的执行计划 放入过程缓存
存储过程的后续处理
计算机科学与技术专业
若符合下列条件,则 SQL Server 使用在内存中的计划 来执行随后的查询
当前的环境和计划编译时的环境相同。服务器、数据库 和连接的设置决定了环境
计算机科学与技术专业
CREA输TE出P参RO数C:pr以oc1OUTPUT 关键字指定的变量
@A int , @B int , @RESULT int OUTPUT AS SET @RESULT = @A * @B GO
执行有输出参数的存储过程
DECLARE @answer int EXEC proc1 4, 7, @answer OUTPUT SELECT @answer as ANSWER
存储过程引用的对象不需要名称解析。若被不同用户拥 有的对象具有相同的名字,则需要名称解析。
一个执行计划产生后,驻留在过程缓存中。仅当需要空间 时,SQL Server 将老的、没用的计划移出缓存
存储过程的后续处理(续)
计算机科学与技术专业
检索到的执行计划 执行计划
SELECT * FROM dbo.member WHERE member_no = ?
USE Northw@ind参数名 数据类型 [=默认值]
GO CREATE PROC dbo.OverdueOrders2 @Employee_ID int , @Order_date datetime
AS SELECT CONVERT(char(8), OrderDate, 1) OrderDate,
=@changkuhao select @avggz=avg(工资) from 职工 where 仓库号
=@changkuhao end
广西大学信息网络中心 卢豫开
计算机科学与技术专业
实例3:带有输入、输出参数的存储过程的创建与执行
Declare @x1 int,@x2 real Execute hyproc3 'wh1',@x1 output,@x2
定义存储过程
计算机科学与技术专业
存储过程
是存储在服务器上的 Transact-SQL 语句的命名集合 是封装重复性任务的方法 支持用户声明变量、条件执行以及其他强有力的编程特性
SQL Server 中的存储过程与其他编程语言中的过程类似,它可以
包含执行数据库操作(包括调用其他过程)的编程语句 接受输入参数 向调用过程或批处理返回状态值,以表明成功或失败(以
output Select @x1 as wh1职工最大工资,@x2 as
@Order_date = '1996-7-17'
EXEC OverdueOrders2 @Order_date = '1996-7-17', @Employee_ID = 1
通过位置传递参数(顺序保持一致)
EXEC OverdueOrders2 1 , '1996-7-17'
使用输出参数返回值
储过程。
广西大学信息网络中心 卢豫开
计算机科学与技术专业
实例2:带有输入参数的存储过程的创建与执行
代码: Create proc hyproc2 @mingz int,@maxgz int as Select * from 职工 where 工资 between @mingz and
@maxgz 执行: Execute hyproc2 1500,2000
提供了安全性机制。用户可以被赋予执行存储过程的权限,而不必 在存储过程引用的所有对象上都有权限
改善性能。预编译的 Transact-SQL 语句,可以根据条件决定执 行哪一部分
减少网络通信量。客户端用一条语句调用存储过程,就可以完成可 能需要大量语句才能完成的任务,这样减少了客户端和服务器之间 的请求/回答包
必须定义一个变量, 以接受返回值
写上OUTPUT,才 可以接收到返回值
计算机科学与技术专业
实例1:不带参数的存储过程的创建与执行
输入代码: Create proc hyproc1 as Select * from 职工 where 工资 > 1800 执行代码: Execute hyproc1 在进行实验时请注意各数据库中的同名表和同名存