• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
cnsdhzzl
博客园    首页    新随笔    联系   管理    订阅  订阅
mybatis调用存储过程的两种方式

先总结和说明一下注意点:

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相同

 

posted on 2017-08-25 11:10  cnsdhzzl  阅读(1237)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3