1、MyBatis调用存储过程MyBatis支持使用存储过程的配置。当使用存储过程时,需要设置一个参数“mode”,其值有IN(输入参数)、OUT(输出参数)和INOUT(输入/输出参数)。 MyBatis定义存储过程如下: 1 2 3 4 | <!
< select id= "selectSomeThing" statementType= "CALLABLE" parameterType= "hashmap" resultType= "com.pjb.mybatis.po.User" >
{CALL PROC_FOR_INPUT(#{information,mode= IN ,jdbcType= VARCHAR })}
</ select >
|
【示例】创建存储过程,实现分页查询用户列表,并返回数据总数和总页数,通过MyBatis调用该存储过程。 (1)在MySQL数据库中创建用户信息表(tb_user)。 1 2 3 4 5 6 7 | CREATE TABLE IF NOT EXISTS tb_user
(
id INT AUTO_INCREMENT PRIMARY KEY COMMENT '用户编号' ,
user_name VARCHAR (50) NOT NULL COMMENT '用户姓名' ,
sex CHAR (2) DEFAULT '男' COMMENT '性别'
) COMMENT = '用户信息表' ;
|
(2)创建存储过程,实现分页查询用户列表,并返回数据总数和总页数。 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 | DELIMITER $$
/*
*/
CREATE PROCEDURE proc_search_user( IN page_index INT , IN page_size INT , OUT total_count INT , OUT total_page INT )
BEGIN
DECLARE begin_no INT ;
SET begin_no = (page_index-1)*page_size;
SELECT * FROM tb_user
WHERE id >= (
SELECT id FROM tb_user
ORDER BY id ASC
LIMIT begin_no,1
)
ORDER BY id ASC
LIMIT page_size;
SELECT COUNT (1) INTO total_count FROM tb_user;
SET total_page = FLOOR((total_count + page_size - 1) / page_size);
END $$
DELIMITER ;
|
(3)创建用户信息持久化类(User.java)。 1 2 3 4 5 6 7 8 9 10 11 12 13 14 | package com.pjb.mybatis.po;
/**
* 用户信息的持久化类
* @author pan_junbiao
**/
public class User
{
private int id;
private String userName;
private String sex;
}
|
(4)编写SQL映射配置。 1 2 3 4 5 6 7 | <!
< select id= "proc_search_user" statementType= "CALLABLE" parameterType= "hashmap" resultType= "com.pjb.mybatis.po.User" >
{CALL proc_search_user(#{page_index,mode= IN ,jdbcType= INTEGER },
#{page_size,mode= IN ,jdbcType= INTEGER },
#{total_count,mode= OUT ,jdbcType= INTEGER },
#{total_page,mode= OUT ,jdbcType= INTEGER })}
</ select >
|
(5)编写执行方法。 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 | /**
* 使用MyBatis调用存储过程:分页查询用户列表,并返回数据总数和总页数
* @author pan_junbiao
*/
@Test
public void procSearchUser()
{
DataConnection dataConnection = new DataConnection();
SqlSession sqlSession = dataConnection.getSqlSession();
Map params = new HashMap();
params.put( "page_index" , 2 );
params.put( "page_size" , 10 );
params.put( "total_count" , 0 );
params.put( "total_page" , 0 );
List<User> userList = sqlSession.selectList( "test.proc_search_user" ,params);
System.out.println( "查询第" + params.get( "page_index" ) + "页的数据,每页共" +params.get( "page_size" )+ "条数据" );
for (User user : userList)
{
System.out.println( "编号:" + user.getId() + " 姓名:" + user.getUserName() + " 性别:" + user.getSex());
}
System.out.println( "数据总数:" + params.get( "total_count" ));
System.out.println( "总页数:" + params.get( "total_page" ));
sqlSession.close();
}
|
执行结果: 
【示例】创建存储过程,实现新增用户信息,并返回自增主键,通过MyBatis调用该存储过程。 (1)创建存储过程。 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | DELIMITER $$
/*
*/
CREATE PROCEDURE proc_add_user( IN user_name VARCHAR (50), IN sex CHAR (2), OUT user_id INT )
BEGIN
INSERT INTO tb_user(user_name,sex) VALUE (user_name,sex);
SELECT LAST_INSERT_ID() INTO user_id;
END $$
DELIMITER ;
|
(2)编写SQL映射配置。 1 2 3 4 5 6 | <!
< insert id= "proc_add_user" statementType= "CALLABLE" parameterType= "com.pjb.mybatis.po.User" >
{CALL proc_add_user(#{userName,mode= IN ,jdbcType= VARCHAR },
#{sex,mode= IN ,jdbcType= CHAR },
#{id,mode= OUT ,jdbcType= INTEGER })}
</ insert >
|
(3)编写执行方法。 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | /**
* 使用MyBatis调用存储过程:新增用户信息,返回自增主键
* @author pan_junbiao
*/
@Test
public void procAddUser()
{
DataConnection dataConnection = new DataConnection();
SqlSession sqlSession = dataConnection.getSqlSession();
User user = new User();
user.setUserName( "pan_junbiao的博客" );
user.setSex( "男" );
int reuslt = sqlSession.insert( "test.proc_add_user" ,user);
sqlSession.commit();
System.out.println( "执行结果:" +reuslt);
System.out.println( "自增主键:" +user.getId());
sqlSession.close();
}
|
执行结果: 
其实,新增数据后,获取自增主键是可以使用MyBatis提供的<selectKey>标签,SQL映射配置如下: 1 2 3 4 5 6 7 8 | <!
< insert id= "proc_add_user" statementType= "CALLABLE" parameterType= "com.pjb.mybatis.po.User" >
<selectKey keyProperty= "id" order = "AFTER" resultType= "java.lang.Integer" >
SELECT LAST_INSERT_ID()
</selectKey>
{CALL proc_add_user(#{userName,mode= IN ,jdbcType= VARCHAR },
#{sex,mode= IN ,jdbcType= CHAR })}
</ insert >
|
但上述示例是为了能让该存储过程拥有一个返回的参数。
2、MyBatis调用存储函数【示例】创建存储函数,根据用户编号,获取用户名称,通过MyBatis调用该存储函数。 (1)创建存储函数,根据用户编号,获取用户名称。 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 | DELIMITER $$
/*
*/
CREATE FUNCTION func_get_user_name(in_id INT )
RETURNS VARCHAR (50)
BEGIN
DECLARE out_name VARCHAR (50);
SELECT user_name INTO out_name FROM tb_user WHERE id = in_id;
RETURN out_name;
END $$
DELIMITER ;
|
(2)编写SQL映射配置。 1 2 3 4 | <!
< select id= "func_get_user_name" statementType= "CALLABLE" parameterType= "hashMap" >
{#{userName,mode= OUT ,jdbcType= VARCHAR } = CALL func_get_user_name(#{userId,mode= IN ,jdbcType= INTEGER })}
</ select >
|
(3)编写执行方法。 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | /**
* 使用MyBatis调用存储函数:根据用户编号,获取用户名称
* @author pan_junbiao
*/
@Test
public void funcGetUserName()
{
DataConnection dataConnection = new DataConnection();
SqlSession sqlSession = dataConnection.getSqlSession();
Map userMap = new HashMap();
userMap.put( "userName" , "" );
userMap.put( "userId" , 8 );
sqlSession.selectOne( "test.func_get_user_name" ,userMap);
System.out.println( "用户名称:" + userMap.get( "userName" ));
sqlSession.close();
}
|
执行结果: 
|