Mybatis調用Oracle中的存儲過程和function

一、Mybatis調用存儲過程

1 在數據庫中創建以下的存儲過程
create or replace procedure pro_hello(p_user_name in varchar2,p_result out varchar2) is
begin
  p_result := 'hello,' || p_user_name;
end;
//------------------------------------------

在mysql數據庫中創建存儲過程

create procedure pro_name([in] p_user_name varchar(10),[in] p_result varchar(10))

begin

 p_result := 'hello,' || p_user_name;

end

//注意聲明參數的in/out/in out 的位置以及參數類型的長度在mysql中需要聲明


2 編寫SQL映射文件mapper.xml
statementType裏的CALLABLE是標註此sql爲存儲過程。
parameterType是標註要傳的參數,看了一些資料不寫parameterType的話默認傳map。還是加上比較清晰
<select id="proHello" parameterType="java.util.map" statementType="CALLABLE">
{call pro_hello(#{uname,mode=IN,jdbcType=VARCHAR},#{result,mode=OUT,jdbcType=VARCHAR})}
</select>

3 編寫JAVA代碼調用存儲過程
public class ProcedureTest { 
         public static void main(String[] args) throws IOException {
            String resource = "mybatis.cfg.xml";
            Reader reader = Resources.getResourceAsReader(resource);
            SqlSessionFactory ssf = new SqlSessionFactoryBuilder().build(reader);
            SqlSession session = ssf.openSession();
            try {
                 Map<String, String> param = new HashMap<String, String>();
                 param.put("uname", "zhangsan");
                 param.put("result", "");
                 String returnValue = (String) session.selectOne("User.proHello", param);
                 System.out.println("message=" + param.get("uname"));
                 System.out.println("result=" + param.get("result"));
                 System.out.println("returnValue=" + returnValue); 
           } catch (Exception e) {
                e.printStackTrace();
           } finally {
              session.close();
          }
       }
}


二、Mybatis調用function

function帶有返回值,假設一個oracle函數增加學生後返回成功與否的字符串
<select id="isMember" statementType="CALLABLE" parameterType="cn.StudentDto">  
{#{result,mode=OUT,jdbvType=VARCHAR} = call 
addStudent(#{num,mode=IN,jdbcType=DECIMAL},#{name,mode=IN,jdbcType=VARCHAR},#{rollInYear,mode=IN,jdbcType=Date},#{age,mode=OUT,jdbcType=INTEGER})}  
</select>

StudentDTO除了上述出現的學生信息字段外還需要String類型的result字段。

 

原帖地址:

http://chenjc-it.iteye.com/blog/1443432

http://shen84121062.iteye.com/blog/1213857

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章