springboot mybatis调用mysql创建的带事务的存储过程并返回值

一、创建存储过程

CREATE ` PROCEDURE `alterSaleBespeakTime`(
in bespeakId int, in oldAmountId int, in newAmountId int,
in newBespeakDate date,in newStartTime varchar(50),in newEndTime varchar(50), 
in oldBespeakDate date,oldStartTime varchar(50),in oldEndTime varchar(50),
out result int)
BEGIN
	-- 定义错误码
	DECLARE t_error INTEGER DEFAULT 0;   
	-- 当出现异常时错误码赋1
	DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SET t_error=1; 
	-- 开启事务
	start TRANSACTION;
	-- 开始事务处理
	-- 修改司机预约时间
	update sale_driver_bespeak set start_time = newStartTime,end_time = newEndTime,bespeak_date = newBespeakDate,alter_time = now() where id = bespeakId;
	-- 修改旧预约量的时间
	update sale_bespeak_amount set start_time = newStartTime,end_time = newEndTime,bespeak_date = newBespeakDate where id = oldAmountId;
	-- 修改新预约量的时间
	update sale_bespeak_amount set start_time = oldStartTime,end_time = oldEndTime,bespeak_date = oldBespeakDate where id = newAmountId;
	-- 如果出现异常回滚事务,否则提交事务
	IF t_error = 1 THEN  
		ROLLBACK; 
		set result = 0;
	ELSE    
    COMMIT;
		set result = 1;
  END IF;
	END

二、mybatis mapper.xml中调用存储过程并获取返回值

    <select id="alterSaleBespeakTime" resultType="java.lang.Integer">
        set @result=0;
        call alterSaleBespeakTime(#{param1},#{param2},#{param3},#{param4},#{param5},
            #{param6},#{param7},#{param8},#{param9},@result);
        select @result;
    </select>
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值