MS SQL中的return&output的學習

本文介绍了SQL Server中使用输出参数(output)和返回值(return)的方法。通过具体示例展示了如何在存储过程中设置和获取输出参数,以及如何利用返回值进行条件判断。这两种机制为SQL编程提供了灵活性。

 

/*output的應用*/
CREATE PROCEDURE [dbo].[sp_output]
(
   
@i char(1)='1',
   
@a varchar(5)=null output
)
 
AS
begin
  
if(@i='1')
    
set @a='aaaaa'
  
else
    
set @a='bbbbb'
end
GO
/*存儲過程內調用*/
CREATE PROCEDURE [dbo].[test_output]
(
  
@i char(1)='1'
)
 
AS
begin
  
declare @b varchar(5)
  
exec sp_output @i,@b output
  
print @b
end
GO
/*sql script 調用*/
declare @a varchar(5)
exec sp_output '2',@a output
print @a

/*return的應用*/
CREATE PROCEDURE [dbo].[sp_return]
(
   
@i char(1)='1'
)
 
AS
begin
  
/*
  --return只能返回一個int類型的值,相反output則可以傳回更多類型的值
  無條件退出查詢或程序。RETURN 是立即而完整的,而且可在任何時刻用於退出程序、批次,或陳述式封鎖。
  其中附隨有 RETURN 的陳述式不會被執行。
  
*/
  
  
if(@i='1')
    
return 1
  
else
    
return 0
end
GO

/*存儲過程內調用*/

CREATE PROCEDURE [dbo].[test_return]
(
  
@i char(1)='1'
)
 
AS
begin
  
declare @b varchar(5)
  
exec @b=sp_return @i
  
if (@b=1)
    
print('aaaaa')
  
else
    
print('bbbbb')
end
GO

/*sql script 調用*/
declare @b int
exec @b=sp_return '1'
if (@b=1)
  
print('aaaaa')
else
  
print('bbbbb')

/*return & output同時應用*/
CREATE PROCEDURE [dbo].[sp_output_return]
(
   
@i char(1)='1',
   
@a varchar(5)=null output
)
 
AS
begin
  
if(@i='1')
  
begin
    
set @a='aaaaa'
    
return 1
  
end
  
else
  
begin
    
set @a='bbbbb'
    
return 0
  
end
end
GO

/*存儲過程內調用*/
CREATE PROCEDURE [dbo].[test_output_return]
(
  
@i char(1)='1'
)
 
AS
begin
  
declare @b int
  
declare @a varchar(5)
  
exec @b=sp_output_return @i,@a output
  
print(@a)
  
print(@b)
end
GO


/*sql script 調用*/
declare @a varchar(5)
declare @b int
exec @b=sp_output_return '1',@a output
print @a
print @b
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值