存储过程在小公司用的不多,但是如果业务比较复杂或者性能要求比较苛刻的时候存储过程就派上用场了,ibatis的前期的一些版本貌似不支持存储过程因此我选择了mybatis来做实验。
1.无输入和输出参数的存储过程
我写了一个比较简单的,需要注意的是Oracle无参存储过程不能写括号
CREATE OR REPLACE Procedure cascadeoperation
As
Begin
Delete From teacher Where id=1;
Update studentdetail Set address=’宁波市海曙区’ Where studentid=10;
End;
这里执行了2个操作,可能用过mybatis的人会迷惑执行的时候到底使用update标签呢还是delete标签,其实都行,我也试过select标签也是OK的,下面是部分的配置文件
{call cascadeoperation}
2.带有输入和输出参数的存储过程
,我这里加入了if else的几个判断
CREATE OR REPLACE Procedure queryTeacher(fid In Integer,Type In Varchar,Name Out Varchar)
As
Begin
If Type=’1’ then
Select Name Into Name From student Where id=fid;
Else if Type=’2’ Then
Select Name Into Name From teacher Where id=fid;
Else
Name:=’错误’;
End If;
End If;
End;
下面顺便把我在命令行窗口执行的存储过程语句贴出来
Declare
Name Varchar2(50);
Begin
queryteacher(3,’2’,Name);
DBMS_OUTPUT.put_line(Name);
End;
/
执行过类似语句的时候可能看不到任何的输出,不要着急只需在命令行使用set serveroutput on;
看到结果了吧,下面使用mybatis来执行这个存储过程,下面是映射文件的写法
{call queryTeacher(#{fid,mode=IN,jdbcType=INTEGER},#{type,mode=IN,jdbcType=VARCHAR},#{name,mode=OUT,jdbcType=VARCHAR})}
那怎么取得返回的内容呢,其实只要存储过程执行后map里就有值了,java代码大致如下
Map
本文介绍了如何使用MyBatis执行Oracle存储过程,包括无参数和带参数的存储过程,并展示了具体的实现步骤与配置文件。

1万+

被折叠的 条评论
为什么被折叠?



