MyBatis调用存储过程与存储函数

1、MyBatis调用存储过程

MyBatis支持使用存储过程的配置。当使用存储过程时,需要设置一个参数“mode”,其值有IN(输入参数)、OUT(输出参数)和INOUT(输入/输出参数)。MyBatis定义存储过程如下:

<!-- 存储过程 -->
<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)。

-- 创建“用户信息”数据表
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)创建存储过程,实现分页查询用户列表,并返回数据总数和总页数。

-- 将结束标志符更改为$$
DELIMITER $$

/*
  -- 存储过程:分页查询用户列表,并返回数据总数和总页数
  -- 输入参数:page_index:当前页码
  -- 输入参数:page_size:分页大小
  -- 输出参数:total_count:数据总数
  -- 输出参数:total_page:总页数
*/
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)。

package com.pjb.mybatis.po;

/**
 * 用户信息的持久化类
 * @author pan_junbiao
 **/
public class User
{
    private int id; //用户编号
    private String userName; //用户姓名
    private String sex; //性别

    //省略getter与setter方法...
}

(4)编写SQL映射配置。

<!-- 存储过程:分页查询用户列表,并返回数据总数和总页数 -->
<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)编写执行方法。

/**
 * 使用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)创建存储过程。

-- 将结束标志符更改为$$
DELIMITER $$

/*
  -- 存储过程:新增用户信息,返回自增主键
  -- 输入参数:user_name:用户姓名
  -- 输入参数:sex:性别
  -- 输出参数:user_id:自增主键
*/
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映射配置。

<!-- 存储过程:新增用户信息,返回自增主键 -->
<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)编写执行方法。

/**
 * 使用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映射配置如下:

<!-- 存储过程:新增用户信息,返回自增主键 -->
<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)创建存储函数,根据用户编号,获取用户名称。

-- 将结束标志符更改为$$
DELIMITER $$

/*
  -- 存储函数:根据用户编号,获取用户名称
  -- 输入参数:in_id:用户编号
  -- 返回结果:用户名称
*/
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映射配置。

<!-- 存储函数:根据用户编号,获取用户名称 -->
<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)编写执行方法。

/**
 * 使用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();
}

执行结果:

 

  • 7
    点赞
  • 39
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
### 回答1: 使用MyBatis调用Oracle存储过程可以按照以下步骤进行: 1. 在mapper XML 文件中定义存储过程调用语句,可以使用 select、update、insert 等标签,如: ``` <select id="callProcedure" statementType="CALLABLE"> {call PROCEDURE_NAME(#{param1,mode=IN,jdbcType=VARCHAR},#{param2,mode=OUT,jdbcType=CURSOR,resultMap=RESULT_MAP})} </select> ``` 其中,PROCEDURE_NAME 为存储过程的名称,param1 和 param2 分别为输入参数和输出参数的名称,RESULT_MAP 是输出结果集的映射关系。 2. 在代码中调用 mapper 方法,如: ``` MyMapper mapper = sqlSession.getMapper(MyMapper.class); Map<String, Object> params = new HashMap<String, Object>(); params.put("param1", "input_value"); mapper.callProcedure(params); List<ResultType> results = (List<ResultType>)params.get("param2"); ``` 其中,MyMapper 为 mapper 的接口类,sqlSession 是 MyBatis 的会话对象,params 是参数 Map 对象,ResultType 是输出结果集的类型。调用 mapper 方法后,会将参数传入存储过程,执行存储过程,并将输出结果集放入 params 对象的 param2 属性中,最后通过 params.get("param2") 可以获取输出结果集。 ### 回答2: 在MyBatis调用Oracle存储过程需要以下步骤: 1. 在Oracle数据库中创建存储过程。示例如下: CREATE OR REPLACE PROCEDURE my_proc (param1 IN VARCHAR2, param2 OUT VARCHAR2) AS BEGIN -- 存储过程的逻辑代码 -- 可以使用IN参数param1进行操作 -- 将OUT参数param2赋值 END; 2. 在MyBatis的Mapper XML文件中编写调用存储过程的代码。示例如下: <insert id="callMyProc" statementType="CALLABLE"> {call my_proc(#{param1}, #{param2, mode=OUT, jdbcType=VARCHAR})} </insert> 3. 在Java代码中调用Mapper中的方法。示例如下: String param1 = "value1"; String param2; MyMapper mapper = sqlSession.getMapper(MyMapper.class); mapper.callMyProc(param1, param2); System.out.println("param2: " + param2); 在上述代码中,param1为传入存储过程的参数值,param2为输出参数。通过调用Mapper中的方法,将param1传入存储过程,并将结果赋值给param2。 其中,CALLABLE为MyBatis的一个特殊语句类型,用于调用存储过程函数。#{param1}和#{param2}用于替换存储过程中的参数。 需要注意的是,通过Mapper调用存储过程后,param2的值会被存储过程赋值。在上述示例中,可以通过System.out.println打印param2的值。 以上就是在MyBatis调用Oracle存储过程的简单示例代码。根据实际业务需求,可以调整参数和存储过程的逻辑。 ### 回答3: 使用MyBatis调用Oracle存储过程需要按照下面的步骤进行操作: 1. 创建存储过程:首先在Oracle数据库中创建存储过程,定义好输入参数、输出参数以及存储过程的逻辑。 2. 在MyBatis的Mapper文件中编写调用存储过程的代码: - 在Mapper文件的命名空间中引入Oracle存储过程的标识符: ``` <mapper namespace="com.example.mapper.MyMapper"> <package name="oracle"/> </mapper> ``` - 编写调用存储过程的代码: ``` <select id="callProcedure" statementType="CALLABLE"> {call PROCEDURE_NAME(#{param1, mode=IN}, #{param2, mode=OUT, jdbcType=VARCHAR})} </select> ``` 其中,`PROCEDURE_NAME`是存储过程的名称,`param1`和`param2`分别是存储过程的输入参数和输出参数。设置`mode=IN`表示输入参数,`mode=OUT`表示输出参数,使用`jdbcType=VARCHAR`指定输出参数的类型。 3. 在Java代码中调用Mapper接口方法: ``` @Autowired private MyMapper myMapper; public void callProcedure() { String inputParam = "input"; Map<String, Object> outputParam = new HashMap<>(); outputParam.put("param2", null); myMapper.callProcedure(inputParam, outputParam); String outputValue = (String) outputParam.get("param2"); System.out.println("Output Parameter: " + outputValue); } ``` 在调用存储过程的方法中,传入输入参数的值和一个Map用于接收输出参数的值。在方法执行后,可以从Map中取得输出参数的值。 注意:在进行存储过程调用时,需要确保MyBatis的配置中启用了对Oracle存储过程的支持。 这是使用MyBatis调用Oracle存储过程的基本步骤,根据具体需求和存储过程的不同,代码可能会有所变化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

pan_junbiao

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值