sqlserver中的存储过程写法及调用

1、创建存储过程,并开启事务控制

if exists (select * from dbo.sysobjects where name = N'PROD_NAME' )
DROP PROCEDURE dbo.PROD_NAME
GO

CREATE PROCEDURE [dbo].[PROD_NAME] (
    @parameter1 VARCHAR(10),
    @parameter2 VARCHAR(10)
AS
BEGIN --000
     declare @error int =0 --事务中操作的错误记录
	 --开启事务
    begin transaction
	
	delete from test_table where column1=@parameter1 and column2=@parameter2 
	set @error+=@@ERROR --记录有可能产生的错误号 
	
	insert into test_table(column1,column2,column3,column4) 
	values(@parameter1,@parameter2,'','')
	set @error+=@@ERROR --记录有可能产生的错误号 
	
	    if(@error<>0)
		  begin
			rollback transaction
			return -1 --设置操作结果错误标识
		  end
		else
		  begin
			commit transaction
			return 1 --操作成功的标识
		  end 
END --000
   
GO

2、调用

exec dbo.PROD_NAME '123','abc';
  • 2
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

原来是小雨啊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值