Mybatis调用存储过程/存储函数

1、存储过程

假设存储过程名称为:p_statisticvalue,

输入参数为整数:a,

输出参数为整数:b

则调用存储过程的一般格式如下:

{call p_statisticvalue(

#{a,mode = IN,jdbcType=java.lang.Integer},

#{b,mode=OUT,jdbcType=java.lang.Integer})

}

在如上格式中,IN表示输入参数,OUT表示输出参数,jdbcType传输入输出参数对应的类型,具体什么类型可以根据存储过程返回值来定。

2、存储函数

假设存储函数名为:nexternal,

输入参数整数:a

则调用存储函数的过程为:

nexternal(#{a})

以上分别定义了存储过程、存储函数的一般格式,那么在mybatis中是怎么调用呢?

<select id="selectId" parameterType = "java.lang.Integer" resultType = "java.lang.Integer" statementType = "CALLABLE">
    {
        call p_statisticvalue(

        #{a,mode = IN,jdbcType=java.lang.Integer},

        #{b,mode = OUT,jdbcType=java.lang.Integer})
    }
</select>
<select id = "selectName" parameterType = "java.lang.Integer" resultType = "java.lang.String">
   select nexternal(#{a})
</select>

注意:调用存储过程中,statementType = "CALLABLE"的配置是必不可少的,有该属性,才能调用存储过程。

扩展:Mybatis支持STATEMENT、PREPARED、或CALLABLE的映射类型,分别支持statement,preparedstatement,callablestatement类型,默认是statementType = "PREPARED"

待更新中。。。。。。。。。。。。。。。。。

  • 3
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值