1、mysql创建存储过程
#结束符号默认;, delimiter $$语句表示结束符号变更为$$
delimiter $$
CREATE PROCEDURE `demo`(IN inStr VARCHAR(100), out ourStr VARCHAR(4000))
BEGIN
SET ourStr = '01';
if (inStr == '02') then
set ourStr = '02';
end if;
END$$
#结束符号修改
delimiter ;
2、mybatis调用
(1)注解方式
// key1和key2都是参数map中的key
// key1是需要传入存储过程的值
// key2是用于接收存储过程返回的值,跟获取自增主键类似
@Select("call demo('${key1}', #{key2, mode=OUT, jdbcType=VARCHAR})")
@Options(statementType = StatementType.CALLABLE)
String getDemoValue(Map<String, Object> map);
(2)xml方式
<select id="getDemoValue" resultType="java.lang.String" parameterType="java.util.Map" statementType="CALLABLE">
call demo('${key1}', #{key2, mode=OUT, jdbcType=VARCHAR})
</select>