码迷,mamicode.com
首页 > 数据库 > 详细

mybatis调用Oracle存储过程

时间:2018-10-29 20:03:59      阅读:173      评论:0      收藏:0      [点我收藏+]

标签:except   pac   value   acl   存储   存在   XML   interface   rom   

oracle procedure代码

CREATE OR REPLACE PROCEDURE dept_insert_proc(
  v_deptno dept.deptno%TYPE,
  v_dname dept.dname%TYPE,
  v_loc dept.loc%TYPE,
  v_result OUT NUMBER)
IS
  v_deptCount NUMBER;
BEGIN
  SELECT COUNT(1)INTO v_deptCount FROM dept WHERE deptno=v_deptno ;
  IF v_deptCount>0 THEN
    v_result:=-1;
    DBMS_OUTPUT.put_line(‘部门已存在!‘);
  ELSE
    INSERT INTO dept(deptno,dname,loc)VALUES(v_deptno,v_dname,v_loc);
    v_result:=0;
  DBMS_OUTPUT.put_line(‘新部门添加成功!‘);
  COMMIT;
END IF;
END;
/

 

dao接口

package com.jinlin.dao;

import org.apache.ibatis.annotations.Param;

import com.jinlin.entity.Dept;

public interface CallMapper {
  public void callProcedure(@Param("dept")Dept dept,@Param("result")int result)throws Exception;
}

 

CallMapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<mapper namespace="com.jinlin.dao.CallMapper">
<!-- 调用存储过程 -->
<select id="callProcedure" statementType="CALLABLE">
{
  CALL dept_insert_proc(
    #{dept.deptno,mode=IN},
    #{dept.dname,mode=IN},
    #{dept.loc,mode=IN},
    <!-- out参数必须指定jdbcType -->
    #{result,mode=OUT,jdbcType=NUMERIC}
  )
}
</select>
</mapper>

 

测试

@Test
public void testDaoProcedure()throws Exception {
  Dept dept = new Dept();
  dept.setDeptno(60);
  dept.setDname("魔乐科技");  
  dept.setLoc("北京");
  int result = 0;

  callMapper.callProcedure(dept, result);
  System.out.println(result);
}

 

mybatis调用Oracle存储过程

标签:except   pac   value   acl   存储   存在   XML   interface   rom   

原文地址:https://www.cnblogs.com/jinlin-2018/p/9872260.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!