关于存储过程的创建

本文详细探讨了MySQL存储过程中创建、使用输出参数时遇到的问题及解决方案。通过实例分析了存储过程中的参数传递机制,特别是输出参数的使用规则,包括为何在某些情况下需要明确赋值给输出参数,以及如何处理带有默认值的输入参数。文章旨在帮助读者更深入地理解存储过程的工作原理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

先看一个例题。
【例】创建一个存储过程,计算指定学生(姓名)的总成绩,输入参数–姓名(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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值