myBatis调用带返回值的存储过程(mysql)

本文介绍如何使用MyBatis实现存储过程返回一个String值的过程。从创建存储过程到在mapper.xml及mapper.java中配置,再到service层的调用方法,提供了完整的代码示例。

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

折腾了一上午才顺利的把这个跑通了,废话不多说,上代码!

1.存储过程返回一个String

CREATE PROCEDURE `sp_redblack_prize`(OUT result_record varchar(2000000)){……}

2.在mapper.xml中

在这里要注意:Set resultType="map" on <select> element.  I think for stored proc output parms you either need a map, or an object with getters/setters. 

  <select id="spRedBlack" statementType="CALLABLE" parameterType="java.util.Map" 
   resultType="java.util.Map">
   	{CALL sp_redblack_prize(#{result,mode=OUT,jdbcType=VARCHAR}) } 
  </select>

3.在mapper.java中

String spRedBlack(Map param);
4.在service中调用的方法

        HashMap params = new HashMap(); 
	params.put("result", ""); 
	this.gamblingRedBlackDAO.spRedBlack(params);
	String result = (String) params.get("result");

注:statementType的类型分为:


statement未预编译;

prepared预编译(默认);

callable存储过程;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值