注意:
兼容级别设置确定了是将空字符串 (NULL) 解释为单个空格,还是解释为真正的空字符串。如果兼容级别小于或等于 65,SQL Server 2005 会将空字符串解释为单个空格。如果兼容级别等于 70,SQL Server 会将空字符串解释为空字符串。
参数:
integer_expression返回的整数值。存储过程可向执行调用的过程或应用程序返回一个整数值。
示例:
A. 从过程返回
以下示例显示如果在执行 findjobs 时没有指定用户名作为参数,则 RETURN 将使过程向用户屏幕发送一条消息后退出。如果指定了用户名,则将从相应的系统表中检索此用户在当前数据库创建的所有对象名。
CREATE PROCEDURE findjobs @nm sysname = NULL
AS
IF @nm IS NULL
BEGIN
PRINT 'You must give a user name'
RETURN
END
ELSE
BEGIN
SELECT o.name, o.id, o.uid
FROM sysobjects o INNER JOIN master..syslogins l
ON o.uid = l.sid
WHERE l.name = @nm
END;
B. 返回状态代码
以下示例将检查指定联系人的 ID 的状态。如果所在的州是 Washington (WA),将返回状态代码 1。在其他情况下(StateProvince 的值是 WA 以外的值,或者 ContactID 没有匹配的行),返回状态代码 2。
USE AdventureWorks;
GO
CREATE PROCEDURE checkstate @param varchar(11)
AS
IF (SELECT StateProvince FROM Person.vAdditionalContactInfo WHERE ContactID = @param) = 'WA'
RETURN 1
ELSE
RETURN 2;
GO
从存储过程返回表类型的值也有二种:
1.存储过程使用浮标参数,即同时指定CURSOR VARYING OUTPUT项.调用者可以使用while及fetch循环遍历该浮标.
2.直接将存储过程返回的结果集插入到表中,即使用insert into 表名 exec 存储过程.此种方式中注意存储过程返回的结果集列与insert的列要完全对应,可以在insert中指定列名来保证对应关系.
------------------------------------------------------------------------------
测试:
------------------------------------------------------------------------------
----建立测试用的临时表
create table #tmp (colx int,coly int)
insert into #tmp values(1,2)
insert into #tmp values(2,3)
insert into #tmp values(3,4)
select * from #tmp
GO
----创建返回游标的存储过程
create proc sp_c @cur CURSOR VARYING OUTPUT
AS
begin
set @cur = CURSOR for select colx from #tmp
open @cur /*该过程返回游标,该游标为colx列的查询结果*/
end
GO
----创建返回表的存储过程
create proc sp_d
as
select coly from #tmp /*该过程返回coly列的查询结果*/
go
----创建用于调用以上二个存储过程的存储过程
create proc sp_e
as
begin
declare @x int
declare @cur cursor
----接收游标,并遍历游标
EXEC sp_c @cur OUTPUT
fetch next from @cur into @x
while (@@FETCH_STATUS = 0)
begin
print @x
fetch next from @cur into @x
END
close @cur
deallocate @cur
----将存储过程返回的列值再重新插入源表中
insert into #tmp(coly) EXEC sp_d
select * from #tmp
end
GO
EXEC sp_e
drop proc sp_c
drop proc sp_d
drop proc sp_e
drop table #tmp
从存储过程返回非表类型的值有二种方法:
1.存储过程使用return语句返回值.此种情况下,接收该存储过程值的方法是:
delcare @ReturnValue int /*(与存储过程return语句返回值的类型相同)*/
exec @ReturnValue = StoredProc
2.存储过程使用OUTPUT输出参数.此种情况下,直接使用OUTPUT输出参数即可:
declare @id int
set @id = 1
exec StoreProc @id OUTPUT
select @id
测试:
create proc sp_b @id int OUTPUT
AS
begin
set @id = 100 /*为输出参数赋值*/
return 99 /*返回值*/
end
go
create proc sp_a
as
begin
declare @rtv int
declare @id int
exec @rtv = sp_b @id OUTPUT
print @rtv
print @id
end
go
exec sp_a
drop proc sp_a
drop proc sp_b