Mybatis框架之工厂模式(Factory Pattern)

 更新时间:2024年11月19日 10:03:53   作者:Katie。  
MyBatis中使用工厂模式来管理和创建SqlSession对象,从而简化数据库访问的配置和管理过程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

MyBatis 中的工厂模式(Factory Pattern)主要体现在 SqlSessionFactory 和 SqlSession 的使用上。MyBatis 使用工厂模式来管理和创建 SqlSession 对象,从而简化数据库访问的配置和管理过程。下面将详细介绍 MyBatis 中的工厂模式的原理和实现。

1. 什么是工厂模式 (Factory Pattern)?

工厂模式 是一种创建型设计模式,它提供了一种创建对象的方式,使得客户端无需指定对象的具体类名,而是通过一个统一的接口来创建对象。这种模式通过定义一个工厂类来封装对象的创建过程,可以将对象的创建与使用解耦,从而提高代码的灵活性和可维护性。

2. MyBatis 中的工厂模式实现

在 MyBatis 中,SqlSessionFactory 就是一个典型的工厂模式的实现。它负责创建和管理 SqlSession 对象。SqlSession 是 MyBatis 提供的用于操作数据库的核心接口。

2.1 SqlSessionFactory 的角色

  • SqlSessionFactory:充当工厂类,用于创建 SqlSession 对象。SqlSession 是一个会话对象,用于执行 SQL 语句、获取 Mapper 接口实例、以及管理事务。
  • SqlSessionFactoryBuilder:是创建 SqlSessionFactory 的工具类。它负责解析 MyBatis 配置文件,并基于这些配置创建 SqlSessionFactory

3. MyBatis 工厂模式的实现步骤

以下是 MyBatis 工厂模式的实现步骤:

3.1 创建 MyBatis 配置文件 (mybatis-config.xml)

这是 MyBatis 的全局配置文件,用于设置数据源、环境和其他配置信息。

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
    PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
    "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.cj.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/mydatabase"/>
                <property name="username" value="root"/>
                <property name="password" value="password"/>
            </dataSource>
        </environment>
    </environments>
    <mappers>
        <mapper resource="com/example/mapper/UserMapper.xml"/>
    </mappers>
</configuration>

3.2 创建 Mapper 接口 (UserMapper.java)

Mapper 接口定义了数据库操作方法。

package com.example.mapper;

import com.example.model.User;
import java.util.List;

public interface UserMapper {
    List<User> getAllUsers();
    User getUserById(int id);
}

3.3 编写 Mapper XML 文件 (UserMapper.xml)

定义 SQL 语句。

<?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.UserMapper">
    <select id="getAllUsers" resultType="com.example.model.User">
        SELECT * FROM users;
    </select>
    <select id="getUserById" parameterType="int" resultType="com.example.model.User">
        SELECT * FROM users WHERE id = #{id};
    </select>
</mapper>

3.4 使用 SqlSessionFactoryBuilder 创建 SqlSessionFactory

在 Java 应用程序中,使用 SqlSessionFactoryBuilder 创建 SqlSessionFactory,并通过 SqlSessionFactory 获取 SqlSession

import java.io.InputStream;
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 com.example.mapper.UserMapper;
import com.example.model.User;
import java.util.List;

public class MyBatisExample {
    public static void main(String[] args) {
        String resource = "mybatis-config.xml";
        try (InputStream inputStream = Resources.getResourceAsStream(resource)) {
            // 1. 创建 SqlSessionFactory
            SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
            
            // 2. 从工厂获取 SqlSession
            try (SqlSession session = sqlSessionFactory.openSession()) {
                // 3. 获取 Mapper 接口的实现
                UserMapper userMapper = session.getMapper(UserMapper.class);
                
                // 4. 调用方法执行 SQL
                List<User> users = userMapper.getAllUsers();
                users.forEach(user -> System.out.println(user.getName()));
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

4. MyBatis 工厂模式的工作流程

  • SqlSessionFactoryBuilder 解析 MyBatis 配置文件 (mybatis-config.xml) 并构建 SqlSessionFactory 对象。
  • SqlSessionFactory 负责创建和管理 SqlSession 对象。
  • SqlSession 提供用于执行 SQL 语句、获取 Mapper 接口、提交或回滚事务的功能。
  • 通过 SqlSession.getMapper() 方法获取 Mapper 接口的实现类,从而执行 SQL 操作。

5. 工厂模式带来的好处

  • 解耦:客户端代码只依赖于 SqlSessionFactory 和 SqlSession 接口,减少了与底层实现的耦合。
  • 资源管理:通过工厂模式,SqlSessionFactory 可以更好地管理数据库连接资源(如连接池)。
  • 代码简洁:使用工厂模式,可以更轻松地创建和管理 SqlSession 对象,减少了重复代码。

6. 总结

MyBatis 通过 SqlSessionFactory 实现了工厂模式,用于创建 SqlSession 对象。工厂模式的使用,使得 MyBatis 的数据库访问层更加灵活、简洁,同时也提高了应用程序的可维护性和扩展性。使用工厂模式,开发者可以更方便地管理数据库连接和事务操作,从而专注于业务逻辑的实现。

到此这篇关于Mybatis框架之工厂模式(Factory Pattern)的文章就介绍到这了,更多相关Mybatis 工厂模式内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:

相关文章

  • java实现斗地主游戏

    java实现斗地主游戏

    这篇文章主要为大家详细介绍了java实现斗地主游戏,洗牌、发牌、看牌,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-01-01
  • mybatis plus 的动态表名的配置详解

    mybatis plus 的动态表名的配置详解

    这篇文章主要介绍了mybatis plus 的动态表名的配置详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • Java设计模式之模板方法模式Template Method Pattern详解

    Java设计模式之模板方法模式Template Method Pattern详解

    在我们实际开发中,如果一个方法极其复杂时,如果我们将所有的逻辑写在一个方法中,那维护起来就很困难,要替换某些步骤时都要重新写,这样代码的扩展性就很差,当遇到这种情况就要考虑今天的主角——模板方法模式
    2022-11-11
  • SpringBoot配置多个数据源超简单步骤(连接多个数据库)

    SpringBoot配置多个数据源超简单步骤(连接多个数据库)

    公司项目有连接多个不同数据库的需求,特研究了一下,根据网上的资料,这篇文章主要给大家介绍了关于SpringBoot配置多个数据源(连接多个数据库)的相关资料,需要的朋友可以参考下
    2024-05-05
  • SpringBoot 如何读取classpath下的文件

    SpringBoot 如何读取classpath下的文件

    这篇文章主要介绍了SpringBoot 读取classpath下的文件方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-06-06
  • Mybatis基础概念与高级应用小结

    Mybatis基础概念与高级应用小结

    这篇文章主要介绍了Mybatis基础回顾与高级应用,本文内容有点小长,希望大家耐心阅读,此文结合实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2022-06-06
  • Java数据结构通关时间复杂度和空间复杂度

    Java数据结构通关时间复杂度和空间复杂度

    对于一个算法,其时间复杂度和空间复杂度往往是相互影响的,当追求一个较好的时间复杂度时,可能会使空间复杂度的性能变差,即可能导致占用较多的存储空间,这篇文章主要给大家介绍了关于Java时间复杂度、空间复杂度的相关资料,需要的朋友可以参考下
    2022-05-05
  • 详解Nacos配置中心的实现

    详解Nacos配置中心的实现

    Spring Cloud Alibaba 是阿里巴巴提供的一站式微服务开发解决方案。而 Nacos 作为 Spring Cloud Alibaba 的核心组件之一,提供了两个非常重要的功能:注册中心和配置中心,我们今天来了解和实现一下二者
    2022-08-08
  • SpringCloud的那些中间件问题

    SpringCloud的那些中间件问题

    这篇文章主要介绍了SpringCloud的那些中间件问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-05-05
  • java 利用反射获取内部类静态成员变量的值操作

    java 利用反射获取内部类静态成员变量的值操作

    这篇文章主要介绍了java 利用反射获取内部类静态成员变量的值操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12

最新评论