前面写了一篇关于存储过程的文章,里面讲述了存储过程的一些理论知识,包括存储过程是什么,类型有哪些,如何创建、查看、修改和删除本地存储过程。今天在做题的过程中,突然发现了几个问题,今天单独拿出来讨论一下。
先看一个例题。
【例】创建一个存储过程,计算指定学生(姓名)的总成绩,输入参数–姓名(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