存储过程的写法

 

CREATE PROCEDURE dbo.sp_consume_create
--月卡,年卡或次卡消费过程
@card_code nvarchar(50),  --会员卡号
@csm_cus_name nvarchar(50), --客户账号
@card_type int, --卡类型
@csm_csmItems int, --消费项目
@csm_coach nvarchar(50),--1对1服务人员
@cms_operator nvarchar(50),--操作人员
@cms_company int, --分店/分公司编号
@cms_remarks nvarchar(100), --消费备注
---------------------------------------------------------------------
@card_points int  -- 积分

AS
 begin transaction
     begin   --增加一条消费记录
     insert into tb_consumeRcd ( csm_card_code,csm_cus_name,csm_csmItems,csm_coach,cms_operator,cms_company,cms_remarks )
     values (@card_code,@csm_cus_name,@csm_csmItems,@csm_coach,@cms_operator,@cms_company,@cms_remarks)
     if @@ROWCOUNT=0
         return 0
     else
         begin --修改会员卡次数和增加积分
         if @card_type = 1 --表示是次卡 更新次数和积分
             update tb_cardInfo set card_times=card_times-1,card_useTimes=card_useTimes+1,card_points=card_points+@card_points,card_usePoints=card_usePoints+@card_points where card_code=@card_code
         else --表示是按时间计算的卡 只更新积分
             update tb_cardInfo set card_points=card_points+@card_points,card_usePoints=card_usePoints+@card_points where card_code=@card_code
         end
     end

 if @@error>0
     begin
         --print '回滚事务.'
         rollback transaction
     end
 else
     begin
         --print '提交事务'
         commit transaction
     end
GO

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值