一、返回select结果集

1、创建存储过程

DELIMITER //
DROP PROCEDURE IF EXISTS proc_queryUser;
CREATE PROCEDURE proc_queryUser(
IN user_name VARCHAR(50) CHARACTER SET utf8
)
BEGIN
SET @exeSql = CONCAT('SELECT id,username,sex,birthday,address ',
'from t_user where username like \'',user_name,'%\' order by id');
-- 打印sql
-- SELECT @exeSql;
-- 预定义一个语句,并将它赋给stmtsql
PREPARE stmtsql FROM @exeSql;
EXECUTE stmtsql;
-- 释放一个预定义语句的资源
DEALLOCATE PREPARE stmtsql; END //
DELIMITER ;

2、存储过程调用

SET @user_name='小';
CALL proc_queryUser(@user_name);

3、在UserMapper.java中添加接口方法

/**调用存储过程查询用户**/
public List findUserByProc(String user_name); /**调用存储过程查询用户**/
public List findUserByProc1(Map map);

4、在UserMapper.xml中添加如下配置项:

<!-- 调用存储过程 -->
<!-- 第一种方式,参数使用parameterType -->
<select id="findUserByProc" parameterType="java.lang.String" statementType="CALLABLE"
resultType="com.mybatis.entity.User">
{call proc_queryUser(#{user_name,jdbcType=VARCHAR,mode=IN})}
</select> <parameterMap type="java.util.Map" id="userMap">
<parameter property="user_name" mode="IN" jdbcType="VARCHAR"/>
</parameterMap> <!-- 调用存储过程 -->
<!-- 第二种方式,参数使用parameterMap -->
<select id="findUserByProc1" parameterMap="userMap" statementType="CALLABLE"
resultType="com.mybatis.entity.User">
{call proc_queryUser(?)}
</select>

说明:这里使用两种方式调用存储过程,两种方式的区别主要在于参数的使用方式上,第一种方式使用parameterType,第二种方式使用parameterMap。

5、测试代码:

package com.mybatis.test;

import java.io.InputStream;
import java.util.HashMap;
import java.util.List;
import java.util.Map; import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Before;
import org.junit.Test; import com.mybatis.entity.User;
import com.mybatis.mapper.UserMapper; public class TestMybatisProceduce { private SqlSessionFactory sqlSessionFactory; // 此方法是在执行@Test方法之前执行
@Before
public void setUp() throws Exception {
String resource = "SqlMapConfig.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
// 创建SqlSessionFcatory
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
} @Test
public void TestProceduce(){
SqlSession sqlSession = sqlSessionFactory.openSession();
// 创建Usermapper对象,mybatis自动生成mapper代理对象
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
List userList = mapper.findUserByProc("小");
System.out.println(userList);
sqlSession.close();
} @Test
public void TestProceduce1(){
SqlSession sqlSession = sqlSessionFactory.openSession();
// 创建Usermapper对象,mybatis自动生成mapper代理对象
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
Map map = new HashMap();
map.put("user_name", "小");
List userList = mapper.findUserByProc1(map);
System.out.println(userList);
sqlSession.close();
}
}

6、运行结果:

[User [id=8, username=小A, sex=2, address=北京, birthday=Sat Jun 27 00:00:00 CST 2015],
User [id=9, username=小B, sex=2, address=北京, birthday=Sat Jun 27 00:00:00 CST 2015],
User [id=10, username=小C, sex=1, address=北京, birthday=Sat Jun 27 00:00:00 CST 2015],
User [id=11, username=小D, sex=2, address=北京, birthday=Sat Jun 27 00:00:00 CST 2015]] [User [id=8, username=小A, sex=2, address=北京, birthday=Sat Jun 27 00:00:00 CST 2015],
User [id=9, username=小B, sex=2, address=北京, birthday=Sat Jun 27 00:00:00 CST 2015],
User [id=10, username=小C, sex=1, address=北京, birthday=Sat Jun 27 00:00:00 CST 2015],
User [id=11, username=小D, sex=2, address=北京, birthday=Sat Jun 27 00:00:00 CST 2015]]

二、带输入输出参数的存储过程

1、创建存储过程

DELIMITER //
DROP PROCEDURE IF EXISTS proc_queryUserCount;
CREATE PROCEDURE proc_queryUserCount(
IN user_name VARCHAR(50) CHARACTER SET utf8,
OUT count INT
)
BEGIN
SET @exeSql = CONCAT('SELECT count(*) into @rowsCount from t_user where username like \'',user_name,'%\'');
-- 打印sql
-- SELECT @exeSql;
-- 预定义一个语句,并将它赋给stmtsql
PREPARE stmtsql FROM @exeSql;
EXECUTE stmtsql;
-- 释放一个预定义语句的资源
DEALLOCATE PREPARE stmtsql;
SET count = @rowsCount; END //
DELIMITER ;

2、存储过程调用:

SET @user_name='小';
CALL proc_queryUserCount(@user_name,@count);
SELECT @count;

3、在UserMapper.java中添加接口方法

 /**调用存储过程(带输入输出参数的存储过程)**/
public void findUserCountByProc(Map map);

4、在UserMapper.xml中添加如下配置项:

<parameterMap type="java.util.HashMap" id="userMap1">
<parameter property="user_name" jdbcType="VARCHAR" mode="IN"/>
<parameter property="count" jdbcType="INTEGER" mode="OUT"/>
</parameterMap> <!-- 调用存储过程 (带输入输出参数的存储过程)-->
<select id="findUserCountByProc" parameterMap="userMap1" statementType="CALLABLE">
{call proc_queryUserCount(?,?)}
</select>

5、测试代码:

@Test
public void TestProceduce2(){
SqlSession sqlSession = sqlSessionFactory.openSession();
// 创建Usermapper对象,mybatis自动生成mapper代理对象
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
Map map = new HashMap();
map.put("user_name", "小");
mapper.findUserCountByProc(map);
System.out.println("userCount="+map.get("count"));
sqlSession.close();
}

6、运行结果:

userCount=4

三、返回多个结果集

1、创建存储过程

DELIMITER //
DROP PROCEDURE IF EXISTS proc_query;
CREATE PROCEDURE proc_query(
IN user_id INT,
OUT order_count INT
)
BEGIN
SET @exeSql = CONCAT('SELECT id,username,sex,date_format(birthday,\'%Y-%m-%d\')birthday,address ',
'from t_user where id=\'',user_id,'\''); PREPARE stmtsql FROM @exeSql;
EXECUTE stmtsql;
DEALLOCATE PREPARE stmtsql; SET @exeSql1 = CONCAT('SELECT id,user_id,number,date_format(createtime,\'%Y-%m-%d %H:%i:%s\')createtime ',
'from orders where user_id=\'',user_id,'\''); PREPARE stmtsql1 FROM @exeSql1;
EXECUTE stmtsql1;
DEALLOCATE PREPARE stmtsql1; SET @exeSql2 = CONCAT('SELECT count(*) into @rowsCount from orders ',
'where user_id=\'',user_id,'\''); PREPARE stmtsql2 FROM @exeSql2;
EXECUTE stmtsql2;
DEALLOCATE PREPARE stmtsql2;
SET order_count = @rowsCount; END //
DELIMITER ;

2、存储过程调用:

SET @user_id=2;
CALL proc_query(@user_id,@order_count);
SELECT @order_count;

3、在UserMapper.java中添加接口方法

/**调用存储过程(返回多个结果集)**/
public List<List<?>> findUserOrdersByProc(Map map);

4、在UserMapper.xml中添加如下配置项:

<resultMap type="java.util.HashMap" id="userInfoMap">
<result column="id" property="id" javaType="java.lang.Integer" jdbcType="INTEGER"/>
<result column="username" property="username" javaType="java.lang.String" jdbcType="VARCHAR"/>
<result column="birthday" property="birthday" javaType="java.lang.String" jdbcType="DATE"/>
<result column="sex" property="sex" javaType="java.lang.String" jdbcType="CHAR"/>
<result column="address" property="address" javaType="java.lang.String" jdbcType="VARCHAR"/>
</resultMap> <resultMap type="java.util.HashMap" id="ordersMap">
<result column="id" property="id" javaType="java.lang.Integer" jdbcType="INTEGER"/>
<result column="user_id" property="user_id" javaType="java.lang.Integer" jdbcType="INTEGER"/>
<result column="number" property="number" javaType="java.lang.String" jdbcType="VARCHAR"/>
<result column="createtime" property="createtime" javaType="java.lang.String" jdbcType="TIMESTAMP"/>
</resultMap> <!-- 调用存储过程 (返回多个结果集)-->
<select id="findUserOrdersByProc" parameterType="java.util.Map" resultMap="userInfoMap,ordersMap"
statementType="CALLABLE">
{call proc_query(#{user_id,jdbcType=INTEGER,mode=IN},
#{order_count,jdbcType=INTEGER,mode=OUT})}
</select>

5、测试代码:

@Test
public void TestProceduce3(){
SqlSession sqlSession = sqlSessionFactory.openSession();
// 创建Usermapper对象,mybatis自动生成mapper代理对象
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
Map map = new HashMap();
map.put("user_id", "2");
List<List<?>> resultList = mapper.findUserOrdersByProc(map);
List<Map> list1 = (List<Map>)resultList.get(0);
List<Map> list2 = (List<Map>)resultList.get(1);
System.out.println(list1);
System.out.println(list2);
System.out.println("orderCount="+map.get("order_count"));
sqlSession.close();
}

6、运行结果:

[{id=2, birthday=2014-07-10, sex=1, username=张三, address=北京市}]
[{createtime=2015-07-17 14:13:23, id=3, number=1000012, user_id=2}]
orderCount=1

四、总结:
如果sql中用的是select出结果,不需要配置out参数。多个结果集/结果集可以配置resultMap 来返回LIST,主要是调用selectList方法会自动把结果集加入到list中去的。

Mybatis学习总结(七)——调用存储过程的更多相关文章

  1. MyBatis学习总结(六)——调用存储过程(转载)

    本文转载自:http://www.cnblogs.com/jpf-java/p/6013518.html 一.提出需求 查询得到男性或女性的数量, 如果传入的是0就女性否则是男性 二.准备数据库表和存 ...

  2. MyBatis学习总结(六)——调用存储过程

    一.提出需求 查询得到男性或女性的数量, 如果传入的是0就女性否则是男性 二.准备数据库表和存储过程 1 create table p_user( 2 id int primary key auto_ ...

  3. MyBatis学习总结(六)——调用存储过程

    一.提出需求 查询得到男性或女性的数量, 如果传入的是0就女性否则是男性 二.准备数据库表和存储过程 create table p_user( id int primary key auto_incr ...

  4. MyBatis学习总结_06_调用存储过程

    一.提出需求 查询得到男性或女性的数量, 如果传入的是0就女性否则是男性 二.准备数据库表和存储过程 1 create table p_user( 2 id int primary key auto_ ...

  5. MyBatis学习笔记(六)——调用存储过程

    转自孤傲苍狼的博客:http://www.cnblogs.com/xdp-gacl/p/4270352.html 一.提出需求 查询得到男性或女性的数量, 如果传入的是0就女性否则是男性 二.准备数据 ...

  6. 六:MyBatis学习总结(六)——调用存储过程

    一.提出需求 查询得到男性或女性的数量, 如果传入的是0就女性否则是男性 二.准备数据库表和存储过程 create table p_user( id int primary key auto_incr ...

  7. MyBatis学习总结(七)——Mybatis缓存(转载)

      孤傲苍狼 只为成功找方法,不为失败找借口! MyBatis学习总结(七)--Mybatis缓存 一.MyBatis缓存介绍 正如大多数持久层框架一样,MyBatis 同样提供了一级缓存和二级缓存的 ...

  8. 【转】MyBatis学习总结(七)——Mybatis缓存

    [转]MyBatis学习总结(七)——Mybatis缓存 一.MyBatis缓存介绍 正如大多数持久层框架一样,MyBatis 同样提供了一级缓存和二级缓存的支持 一级缓存: 基于PerpetualC ...

  9. MySQL 存储过程实例 与 ibatis/mybatis/hibernate/jdbc 如何调用存储过程

    虽然MySQL的存储过程,一般情况下,是不会使用到的,但是在一些特殊场景中,还是有需求的.最近遇到一个sql server向mysql迁移的项目,有一些sql server的存储过程需要向mysql迁 ...

  10. MySQL学习笔记:调用存储过程或函数报1418错误

    问题 MySQL开启bin-log后,调用存储过程或者函数以及触发器时,会出现错误号为1418的错误: ERROR 1418 (HY000): This function has none of DE ...

随机推荐

  1. 被低估的.net(中) - 广州.net俱乐部2019年纲领

    这是被低估的.net系列的中篇.上篇在这里:被低估的.net(上) - 微软MonkeyFest 2018广州分享会活动回顾 中篇本来不是这样的,中篇的草稿大纲其实在写上篇之前就写好了,嗯,当时给张队 ...

  2. H5+混合移动app应用开发——app升级

    当我们的app开发完成之后,无可避免的以后会进行产品升级,那么我们希望在客户的手机上让app进行自动升级,可以分为自动升级和手动升级. 自动升级:一般在客户app第一次打开首页的时候. 手动升级:在a ...

  3. 8.Odoo产品分析 (二) – 商业板块(3) –CRM(2)

    查看Odoo产品分析系列--目录 接上一篇Odoo产品分析 (二) – 商业板块(3) –CRM(1) 4. 设置 在配置–>设置中:    在分析"销售"模块时已经将其他的 ...

  4. 生产环境下JVM调优参数的设置实例

    JVM基础:生产环境参数实例及分析 原始配置: -Xms128m -Xmx128m -XX:NewSize=64m -XX:PermSize=64m -XX:+UseConcMarkSweepGC - ...

  5. 复杂的字符串数组解析:{"setting":"简单:10:5,一般:5:10,困难:2:20"},使用split多次截取

    "[0,{"id":563,"name":"测试题1","dscr":null,"picId&quo ...

  6. Linux16.04 LTS 环境下将cmake的项目转换成eclipse可导入可调试的工程项目

    Linux作为一个开源系统,其中的一个优势就是有效的将各种源码编译得到的库集合在一起,为项目的使用创建了便捷.通常情况下,我们在开发自己的开源项目时,喜欢使用cmake调用各种三方库,如opencv ...

  7. RHEL下SendMail修改发邮箱地址

    RHEL(Oracle Linxu/CentOS)系统下,如果使用sendmail发送邮件,如果不特殊设置,一般发件箱地址为user@hostname,例如,hostname为DB-Server.lo ...

  8. mysql 数据库 命令行的操作——对表和字段的操作

    一.对表的操作 1.查看所有表 show tables: 2.创建表 create table 表名(字段1 类型1 约束1 ,字段2 类型2 约束2): 3.修改表的名字 rename table ...

  9. powershell脚本执行绕过powershell下脚本执行限制(cmd下执行)以及在cmd下隐藏脚本窗口

    powershell脚本执行绕过powershell下脚本执行限制(cmd下执行) powershell脚本运行方式有两种,一种是powshell中运行,另一种是在cmd中(在某些情况下相当有用) p ...

  10. Selenium Webdriver 中的 executeScript 使用方法

    1.使用executeScript 返回一个WebElement . 下例中我们将一个浏览器中的JavaScript 对象返回到客户端(C#,JAVA,Python等). IWebElement el ...