MyBatis调用MySQL存储过程返回结果集

存储过程中经常需要返回结果集。 MySQL 中直接用 select 即可返回结果集。而 Oracle 则需要使用游标来返回结果集。这一点 MySQL 相对比较方便,如下代码即可实现输出结果集:

存储过程定义:

DELIMITER $$
DROP procedure IF EXISTS pro_sql_data1 $$ 
CREATE procedure pro_sql_data1(in sear_name  varchar(2000)) 
BEGIN 
 if sear_name is not null and sear_name!='' then
  select id,name,date_format(create_time,'%Y-%m-%d') as repDate from ad_place where
  name like concat('%',sear_name,'%');
 ELSE
  select id,name,date_format(create_time,'%Y-%m-%d') as repDate from ad_place;
 end if;
 
END$$
DELIMITER;

执行结果:

MyBatis调用MySQL存储过程返回结果集

在mybatis中调用存储过程,然后获取该结果集:

1、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.ifeng.iis.bean.iis.Report" >
 <resultMap type="Java.util.HashMap">
      <result column="id" property="id" javaType="java.lang.Integer" jdbcType="INTEGER"/>
      <result column="name" property="name" javaType="java.lang.String" jdbcType="VARCHAR"/>
      <result column="repDate" property="repDate" javaType="java.lang.String" jdbcType="VARCHAR"/>
      <result column="summ" property="summ" javaType="java.lang.Long" jdbcType="BIGINT"/>
    </resultMap>
   
 <select parameterType="java.util.Map"  resultMap="resultMap" statementType="CALLABLE" > 
      {call pro_sql_data(
      #{obj,jdbcType=VARCHAR,mode=IN}
    )
      }
    </select> 
</mapper>

Java代码

public String query(String param) throws Exception {
  logger.info(param);
  Map queryMap = new HashMap();
  queryMap.put("obj", param);
  //List<Map> listIis1 = reportDao.select4MapParam(queryMap, "currentSql");
 
  List<Map> listIis2 =reportDao.select4MapParam(queryMap,"test123");
 
  return JSONArray.fromObject(listIis2).toString();
 }

注:有上面可知,mysql存储过程中可以直接使用select语句返回结果集,而且mybatis可以直接使用list接收这个结果集(无需游标)。

MyBatis入门学习教程 

Java实战应用:Mybatis实现单表的增删改

[Java][Mybatis]物理分页实现

Mybatis快速入门教程

Mybatis的关于批量数据操作的测试

Mybatis中对List<Object> 对象List的批处理插入操作

MyBatis 的详细介绍请点这里
MyBatis 的下载地址请点这里

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/08ef61574de20d8a658b36be8b709d1a.html