记一次SQLSever存储过程

编写存储过程:根据code,自动匹配对应数据,将对应字段减少num,然后返回计算后的结果num字段的值




USE dbo-- 对应的数据库
GO
 CREATE PROCEDURE z_sp_export @p_code CHAR ( 20 ), @p_num decimal(5,2),@r_num decimal(5,2)  OUTPUT AS 
UPDATE 
	 t_student
SET 
	student_no = student_no - @p_num 
WHERE
	 code  = @p_code;
SELECT
 	@r_num = student_no
FROM
	 t_student
WHERE
 	code = @p_code;
GO

调用存储过程并且返回值

DECLARE @return_value DECIMAL(5,2) EXEC z_sp_export '123',
'2',@return_value OUTPUT SELECT
@return_value AS '返回值'

其他知识

触发器里面有个专用表 deleted ,这个表存储了更新/删除前相应记当的状态,因此,可以查询 deleted 表里面的数据实现获取更新前的值。
注:相应地,还有一个表 inserted 存储即将更新/插入的字段值。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值