SSM-Mybatis调用Oracle存储过程返回结果集(游标)示例

之前一直都是用SSM+Mysql数据库做开发,突然一下子要换成Oracle数据库,感到非常不熟悉.虽然学过Oracle数据库,但由于使用Oracle数据库,牵涉到写存储过程等,所以相对复杂些.根据网上散落的资料,自己在学习之后,做出来的一个示例,分享给大家,以供交流学习.

1.定义包头

oracle存储过程返回结果集需要自定义一个CURSOR(游标变量)性质的变量,这个要在包头定义,所以此处首先创建一个包头.

-- 创建一个包头
-- types: 包名
create or replace
package types
as 
type empListCursor is ref cursor;
end types;

2.创建存储过程

in表示存储过程的输入参数,用out表示存储过程的输出参数,此处输出参数为游标.

CREATE OR REPLACE PROCEDURE 
QUERYEMPSBYDEPTNO(pdeptno in Integer,empList out types.empListCursor) is
BEGIN 
if pdeptno=0 then 
open empList for select * from emp; 
else  
open empList for select * from emp where deptno=pdeptno; 
end if;
END QUERYEMPSBYDEPTNO;

3.EmpMapper.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.casic.dao.EmpMapper"> 

 -- 注意:此处的id要设置成唯一的!!!
 -- 否认会出现如下异常:java.lang.IllegalArgumentException: resultMap3is ambiguous in Result Maps collection

<resultMap id="resultMap3" type="com.casic.model.Emp">
     <result property="empno" column="empno"/> 
     <result property="ename" column="ename"/> 
     <result property="job" column="job"/> 
     <result property="mgr" column="mgr"/> 
     <result property="hiredate" column="hiredate"/>
     <result property="sal" column="sal"/> 
     <result property="comm" column="comm"/> 
     <result property="deptno" column="deptno"/> 
</resultMap>

 <!-- 根据部门编号 查询员工信息列表 --> 
<!--  
statementType="CALLABLE" :表明调用的是存储过程; 
parameterType="java.util.Map" :参数是一个map,所以在传参时需要传入一个map集合.(我尝试了其他的类型,比如int,不行!这点跟mysql不一样); 
-->
 <select id="queryEmpByDeptno" statementType="CALLABLE" parameterType="java.util.Map" >  
<!--传入传出参数要注明mode=IN/OUT 
并要注明jdbcType(在网上可以查询mybatis支持哪些jdbcType类型),
返回参数要注明对应的resultMap  
注意:这里pdeptno,result都是参数map集合的key值. 
-->
 {
    call QUERYEMPSBYDEPTNO(
      #{pdeptno,mode=IN,jdbcType=INTEGER},
      #{result,jdbcType=CURSOR,mode=OUT,javaType=ResultSet, resultMap=resultMap3}
    )
  } 
</select> 
</mapper>

4.EmpMapper.java

package com.casic.dao;
import java.util.List;
import java.util.Map;
import com.casic.model.Emp;
public interface EmpMapper { 
/* * 根据部门编号加载员工信息列表 */ 
List<Emp> queryEmpByDeptno(Map<String, Object> param );
}

5.EmpService.java

package com.casic.service;
import java.util.List;
import java.util.Map;
import com.casic.model.Emp;public interface EmpService {  
/* * 根据部门编号,加载员工信息列表 */ 
List<Emp> queryDeptEmps(Map<String, Object> param);
}

6.EmpServiceImpl.java

package com.casic.service.impl;
import java.util.List;
import java.util.Map;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import com.casic.dao.EmpMapper;
import com.casic.model.Emp;
import com.casic.service.EmpService;
@Service("empService")
public class EmpServiceImp implements EmpService { 
@Autowired 
private EmpMapper empMapper; 
public List<Emp> queryDeptEmps(Map<String, Object> param) { 
//查询的过程中,已经将结果集封装到了param集合中 empMapper.queryEmpByDeptno(param); 
//根据key获取到结果集,并进行强转 
List<Emp> empList=(List<Emp>)param.get("result"); 
return empList; 
}
}

7.EmpController.java

package com.casic.controller;
import java.util.HashMap;
import java.util.List;import java.util.Map;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import com.casic.model.Emp;
import com.casic.service.EmpService;
import oracle.jdbc.driver.OracleTypes;
@Controller
@RequestMapping("/empController")
public class EmpController { 
@Autowired 
private EmpService empService;  
/* * 根据部门编号查询员工信息列表 */ 
@RequestMapping("/queryEmp") 
public String showDeptEmps(Emp emp,Model model){
 Map<String, Object> param = new HashMap<String, Object>(); 
//对于in参数赋值 
param.put("pdeptno",emp.getDeptno()); 
//对于out参数 申明 param.put("result",OracleTypes.CURSOR); 
List<Emp> emps = empService.queryDeptEmps(param); 
model.addAttribute("emps", emps); 
return "showEmps"; 
}
}

8.showEmps.jsp

<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %> 
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> <title>emp list</title> 
</head> 
<body> 
<table cellspacing="1" bordercolor="#990000" cellpadding="1" border="1px">
 <tr> 
  <td> 
  <form action="queryEmp" method="get"> 
    <label>部门编号:</label> 
    <select name="deptno"> 
        <option value="0">全部</option> 
        <option value="10">10</option> 
        <option value="20">20</option> 
        <option value="30">30</option> 
        <option value="40">40</option> 
    </select> 
    <input type="submit" value="Research"> 
  </form> 
  </td> 
</tr> 

<tr> 
    <th>序号</th> 
    <th>编号</th> 
    <th>姓名</th> 
    <th>职位</th>
     <th>领导编号</th>
     <th>入职日期</th>
     <th>工资</th> 
    <th>奖金</th> 
    <th>部门编号</th>  
</tr> 
<c:forEach items="${emps}" var="emp" varStatus="vs"> 
    <tr> 
          <td>${vs.count }</td> 
          <td>${emp.empno }</td> 
          <td>${emp.ename }</td> 
          <td>${emp.job }</td> 
          <td>${emp.mgr }</td> 
          <td><fmt:formatDate pattern="yyyy-MM-dd" value="${emp.hiredate}" /></td> 
          <td>${emp.sal }</td> 
          <td>${emp.comm }</td> 
          <td>${emp.deptno }</td> 
    </tr> 
</c:forEach> 
</table> 
</body>
</html>

9.参考文章

<1> Oracle存储过程,以游标的方式返回一个记录集
<2> mybatis调用oracle存储过程
<3> mybatis 调用存储过程 返回游标 实例
<4> Mybatis调用Oracle返回结果集存储过程

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容

  • 1. 简介 1.1 什么是 MyBatis ? MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的...
    笨鸟慢飞阅读 5,422评论 0 4
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,560评论 18 399
  • oracle存储过程常用技巧 我们在进行pl/sql编程时打交道最多的就是存储过程了。存储过程的结构是非常的简单的...
    dertch阅读 3,472评论 1 12
  • 这几天在制作一个ppt,是用于高中同学聚会的。高中毕业26年了第一次聚会,收集了一些毕业时候的老照片,还有一些黑白...
    鱼啥么阅读 220评论 0 0
  • 如何掌握办公桌及文件的整理方法。 1、在平时的工作中我们会接触到很多的文件,以前可能我们大多会用传统的方式整理这些...
    阿木土阅读 166评论 0 0