zoukankan      html  css  js  c++  java
  • 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相同

  • 相关阅读:
    一个简易的词法分析器
    Wireshark的简单使用
    TCP的三次握手和四次挥手详解
    在WEB显示实时视频流
    linux 下 查看进程的启动时间和运行时间
    mac os x 安装adb
    C++ 和 java 使用 AES CBC 128 加解密
    转:Java中String与byte[]的转换
    对称加密
    Google C++ Style Guide在C++11普及后的变化
  • 原文地址:https://www.cnblogs.com/cnsdhzzl/p/7425412.html
Copyright © 2011-2022 走看看