关于存储过程的创建

前面写了一篇关于存储过程的文章,里面讲述了存储过程的一些理论知识,包括存储过程是什么,类型有哪些,如何创建、查看、修改和删除本地存储过程。今天在做题的过程中,突然发现了几个问题,今天单独拿出来讨论一下。

先看一个例题。
【例】创建一个存储过程,计算指定学生(姓名)的总成绩,输入参数–姓名(nvachar(8)),输出参数–总成绩(int)。
起初,我是这样写的:

create proc this_proc @name nvarchar(8),@sum_score int output
as
select sum(score),sc.sno from sc,student where sname=@name and sc.sno=student.sno 
group by sc.sno
go
declare @score int
exec this_proc '王一',@score output

运行结果如下。
在这里插入图片描述

**但是!**后来我发现这样写存在一个问题:我并没有告诉计算机哪个数值是我要给传出参数的,但是他最后竟然给我输出出来了。随后,我发现事情没那么简单。理应来说,我定义了一个输出参数,那么在存储过程里的select查询就不起输出作用了(表面来看)(后面会解释到),但是,这里之所以能运行出结果来,很显然是select起了作用。所以也就是说,我这里的输出参数计算机没发现它是个输出参数,因为我在存储过程里根本没用。这也就导致了,为什么我运行出结果来了。

然后,我又改了改,原代码变成了这样:

create proc this_proc @name nvarchar(8),@sum_score int output
as
select @sum_score = sum(score) from sc,student 
where sname=@name and sc.sno=student.sno
group by sc.sno
  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值