先总结和说明一下注意点:
1.如果传入的某个参数可能为空,必须指定jdbcType
2.当传入map作为参数时,必须指定JavaType
3.如果做动态查询(参数为表名,sql关键词),可以使用${}原样输出,不会被修改或转义.(不会被mybatis创建预处理语句属性,并安全的设置值)
1.设置传入参数为parameterMap
<select id="cancelReg" statementType="CALLABLE" parameterMap="param" resultType="java.lang.String"> {call P_mzgh_yy_cancel(?,?,?)} </select > <parameterMap id="param" type="java.util.HashMap" > <parameter property="yyid" jdbcType="INTEGER" javaType="int" mode="IN"/> <parameter property="out_return" jdbcType="VARCHAR" javaType="java.lang.String" mode="OUT"/> <parameter property="errortext" jdbcType="VARCHAR" javaType="java.lang.String" mode="OUT"/> </parameterMap >
1.2调用
Map<String,Object> map = new HashMap<String,Object>(); //入参 map.put("yyid", 756704); //返回值变量 map.put("out_return", null); map.put("errortext", null); //执行sql regService.cancelReg(map); //获取返回结果 String result = map.get("out_return").toString();
2.设置传入参数为parameterType
<select id="cancelReg" statementType="CALLABLE" parameterType="map" resultType="java.lang.String"> {call P_mzgh_yy_cancel(#{yyid,mode=IN,jdbcType=INTEGER},#{out_return,mode=OUT,jdbcType=VARCHAR},#{errortext,mode=OUT,jdbcType=VARCHAR})} </select >
2.2调用同1相同