Sybase Oracle SQL 存储过程的创建和执行

Sybase 存储过程的创建和执行

--返回值为int的存储过程
create proc testReturn
@tname varchar(12) ,
@tid int output
as
begin
set @tid = (select testid from Mytest where testname=@tname)
return
end


--返回值为varchar的存储过程
create proc testReturnT
@tid int ,
@tname varchar(12) output
as 
begin 
set @tname = (select testname from Mytest where testid=@tid)
return
end
 

--可以正确执行
declare @tid int 
exec testReturn 'testname', @tid output
select @tid
 

--本意是想直接输出输出参数
declare @tname varchar(12)
exec @tname = testReturnT 3,@tname output
select @tname 
--异常:Implicit conversion from datatype 'INT' to 'VARCHAR' is not allowed.  Use the CONVERT function to run this query.

--正确的执行方法 
declare @tname varchar(12)
declare @tid int 
exec @tid = testReturnT 3,@tname output
select @tid
select @tname

--正确执行
declare @tname varchar(12) 
exec testReturnT 3,@tname output
select @tname 

--注意:Sybase存储过程执行之后 返回值的存储过程成功与否的Int值

Oracle存储过程的创建和执行

--创建
create PROCEDURE testReturn
(tid  in  number ,
tname out NOCOPY varchar2 )
as
begin
select testname into tname from testtable where testid =tid;
end testReturn;

SQL存储过程的创建和执行

--创建
CREATE PROCEDURE procReturn
@tid int ,
@tname varchar(12) output
AS
    select @tname = testname from test1 where testid=@tid
RETURN


--执行
exec procReturn 2,@tname  output


转载于:https://my.oschina.net/u/2245781/blog/639805

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值