Spring Boot整合MyBatis调用存储过程的实现

 更新时间:2026年03月13日 11:06:37   作者:程序员西西  
本文介绍了如何在SpringBoot中整合MyBatis调用存储过程实现,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧

前言

存储过程是一组通过预先编译好的SQL语句,存储在数据库服务器中,被视作是可以执行的单个调用的执行单元,它允许将一系列SQL语句打包成一个逻辑单元,这样可以在需要的时候直接来调用这个逻辑单元来实现相关的操作。在一个存储过程中可以包括常用的复杂数据处理、业务逻辑操作等。

下面我们就来看看如何在Spring Boot中整合MyBatis调用存储过程实现。

存储过程的结构

CREATE PROCEDURE procedure_name(parameters)
BEGIN
    -- SQL statements
END;

其中,参数说明情况如下。

  • procedure_name:存储过程的名称。
  • parameters:存储过程的参数(可选)。

拿一个最经典的场景,来进行说明,例如有一个表格employees,包含员工的姓名和薪水。我们想要创建一个存储过程,根据员工的姓名增加或减少其薪水。可以通过如下的存储过程来实现。

DELIMITER //
    CREATE PROCEDURE update_salary(IN emp_name VARCHAR(50), IN salary_change DECIMAL(10, 2))
    BEGIN
        UPDATE employees
        SET salary = salary + salary_change
        WHERE name = emp_name;
    END //
DELIMITER ;

上面我们创建了一个名为update_salary的存储过程,并且这个存储过程接受了两个参数,员工的姓名(emp_name)和薪水变动的数值(salary_change)。

整个的存储过程包含了一个SQL语句,这个SQL语句就是用来更新员工薪水的SQL语句。要调用存储过程,可以使用 CALL 关键字来执行调用,如下所示。

CALL update_salary('John Doe', 500.00);

这个操作就会为 "John Doe" 的员工的薪水500美元。

使用MyBatis 调用存储过程?

假设我们定义了一个存储过程,用来获取员工信息,并且其会接收一个员工ID的参数作为传入的参数,并且会返回该员工的姓名和薪水,如下所示。

CREATE PROCEDURE get_employee_info(
    IN employeeId INT,
    OUT name VARCHAR(50),
    OUT salary DECIMAL(10, 2)
)
BEGIN
    SELECT name, salary INTO name, salary
    FROM employees
    WHERE id = employeeId;
END;

接下来我们就需要定义一个Mapper的接口用来调用这个存储过程。如下所示。

import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import java.math.BigDecimal;
@Mapper
public interface EmployeeMapper {
    void getEmployeeInfo(@Param("employeeId") int employeeId, @Param("name") String name, @Param("salary") BigDecimal salary);
}

接口定义好之后接下来需要做的事情就是编写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.example.mapper.EmployeeMapper">
    <select id="getEmployeeInfo" statementType="CALLABLE">
        {call get_employee_info(#{employeeId, mode=IN, jdbcType=INTEGER}, #{name, mode=OUT, jdbcType=VARCHAR}, #{salary, mode=OUT, jdbcType=DECIMAL})}
    </select>
</mapper>

调用存储过程的代码实现

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 java.io.IOException;
import java.io.InputStream;
import java.math.BigDecimal;
public class Main {
    public static void main(String[] args) {
        String resource = "mybatis-config.xml";
        try (InputStream inputStream = Resources.getResourceAsStream(resource)) {
            SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
            try (SqlSession sqlSession = sqlSessionFactory.openSession()) {
                EmployeeMapper employeeMapper = sqlSession.getMapper(EmployeeMapper.class);
                int employeeId = 1;
                String name = null;
                BigDecimal salary = null;
                employeeMapper.getEmployeeInfo(employeeId, name, salary);
                System.out.println("Name: " + name);
                System.out.println("Salary: " + salary);
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

这样我们就完成了在MyBatis中调用存储过程的整个操作,启动代码我们就可以看到ID为1的用户的姓名以及薪水信息。

总结

总结一下,在实际操作的过程中,我们当然不会这么使用,在真实的调用场景中可能会结合Controller、Service等处理逻辑来将这个存储过程更好的利用起来,当然了对于参数的配置、异常的处理在配置的时候一定要注意。很多人无法调用存储过程都是因为参数没有传对,所以在实际操作的时候一定要注意相关的操作。

到此这篇关于Spring Boot整合MyBatis调用存储过程的实现的文章就介绍到这了,更多相关Spring Boot整合MyBatis调用存储过程内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • k8s解决java服务下载超时问题小结

    k8s解决java服务下载超时问题小结

    我们在走ingress的java程序的时候,往往会有导出数据的功能,这个时候就会有因网络慢、后台处理时间过长导致下载超时,也有因下载文件太大,导致下载失败,下面给分享k8s解决java服务下载超时问题,感兴趣的朋友跟随小编一起看看吧
    2024-06-06
  • Dubbo在Spring和Spring Boot中的使用详解

    Dubbo在Spring和Spring Boot中的使用详解

    这篇文章主要介绍了Dubbo在Spring和Spring Boot中的使用详解,需要的朋友可以参考下
    2017-10-10
  • windows下使用 intellij idea 编译 kafka 源码环境

    windows下使用 intellij idea 编译 kafka 源码环境

    这篇文章主要介绍了使用 intellij idea 编译 kafka 源码的环境,本文是基于windows下做的项目演示,需要的朋友可以参考下
    2021-10-10
  • 基于Java Tomcat和激活MyEclips的深入理解

    基于Java Tomcat和激活MyEclips的深入理解

    本篇文章是对Java中的Tomcat和激活MyEclips进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • 深入理解Java中的String(示例详解)

    深入理解Java中的String(示例详解)

    文章详细介绍了Java中String类的特点、用途、主要方法以及常见用法,String类是不可变的,具有字符串常量池,特定的内存结构,并随JDK版本更新而优化,它广泛用于表示和处理文本数据,并在内存管理和性能优化方面表现出色,感兴趣的朋友一起看看吧
    2025-03-03
  • 以Java代码的方式总结几个典型的内存溢出案例

    以Java代码的方式总结几个典型的内存溢出案例

    作为程序员,多多少少都会遇到一些内存溢出的场景,如果你还没遇到,说明你工作的年限可能比较短,或者你根本就是个假程序员!哈哈,开个玩笑.今天分享给大家Java内存溢出的相关案例,希望大家在日常工作中,尽量避免写这些low水平的代码,需要的朋友可以参考下
    2021-06-06
  • java 中函数的参数传递详细介绍

    java 中函数的参数传递详细介绍

    这篇文章主要介绍了 java 中函数的参数传递详细介绍的相关资料,需要的朋友可以参考下
    2016-11-11
  • 浅谈java安全编码指南之堆污染

    浅谈java安全编码指南之堆污染

    什么是堆污染呢?是指当参数化类型变量引用的对象不是该参数化类型的对象时而发生的。我们知道在JDK5中,引入了泛型的概念,在创建集合类的时候,指定该集合类中应该存储的对象类型。如果在指定类型的集合中,引用了不同的类型,那么这种情况就叫做堆污染。
    2021-06-06
  • Java 中很好用的数据结构(你绝对没用过)

    Java 中很好用的数据结构(你绝对没用过)

    今天跟大家介绍的就是 java.util.EnumMap,也是 java.util 包下面的一个集合类,同样的也有对应的的 java.util.EnumSet,对java数据结构相关知识感兴趣的朋友一起看看吧
    2022-05-05
  • Spring MVC的项目准备和连接建立方法

    Spring MVC的项目准备和连接建立方法

    SpringWebMVC是基于Servlet API的Web框架,属于Spring框架的一部分,主要用于简化Web应用程序的开发,SpringMVC通过控制器接收请求,使用模型处理数据,并通过视图展示结果,感兴趣的朋友跟随小编一起看看吧
    2024-10-10

最新评论