MyBatis 如何创建 SqlSession 对象的?

news/2025/3/17 1:35:50/

MyBatis 创建 SqlSession 对象的过程主要由 SqlSessionFactory 接口及其实现类来完成。以下是详细步骤:

1. SqlSessionFactory 接口:

  • SqlSessionFactory 是 MyBatis 的核心接口之一,它负责创建 SqlSession 对象。 你可以将 SqlSessionFactory 视为 SqlSession 的工厂。
  • SqlSessionFactory 接口定义了多个 openSession() 方法,用于创建 SqlSession。这些方法提供了不同的选项,例如:
    * openSession(): 使用默认配置(通常是不自动提交事务)。
    * openSession(boolean autoCommit): 指定是否自动提交事务。
    * openSession(ExecutorType execType): 指定执行器类型 (SIMPLE, REUSE, BATCH)。
    * openSession(TransactionIsolationLevel level): 指定事务隔离级别。
    * openSession(Connection connection): 使用外部提供的数据库连接。

2. SqlSessionFactoryBuilder:

  • SqlSessionFactoryBuilder 是一个构建器类,用于构建 SqlSessionFactory 实例。
  • 它提供了多个 build() 方法,可以通过以下方式构建 SqlSessionFactory
    * 从 XML 配置文件 (mybatis-config.xml) 构建。
    * 从 Configuration 对象构建。
    * 从 InputStreamReader 构建。
// 从 XML 配置文件构建 SqlSessionFactory (最常见的方式)
String resource = "mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);// 从 Configuration 对象构建 SqlSessionFactory
Configuration configuration = new Configuration();
// ... 添加配置信息 ...
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(configuration);
  • SqlSessionFactoryBuilder 在构建完 SqlSessionFactory 后,其自身的使命就完成了,通常不需要保留它的实例。最佳实践是在方法内部创建 SqlSessionFactoryBuilder,构建 SqlSessionFactory,然后丢弃 SqlSessionFactoryBuilder

3. DefaultSqlSessionFactory (默认实现):

  • DefaultSqlSessionFactorySqlSessionFactory 接口的默认实现类。
  • SqlSessionFactoryBuilderbuild() 方法通常会创建一个 DefaultSqlSessionFactory 实例。

4. openSession() 方法 (创建 SqlSession 的核心):

  • DefaultSqlSessionFactoryopenSession() 方法(及其重载方法)负责创建 SqlSession 对象。
  • 创建 SqlSession 的过程大致如下:
  1. 获取 Environment:Configuration 对象中获取 Environment 对象,Environment 对象包含了数据源、事务管理器等信息
  2. 创建 Transaction: 根据 Environment 中的 TransactionFactory 创建 Transaction 对象。Transaction 对象负责管理数据库事务。
  3. 创建 Executor: 根据配置信息(例如,defaultExecutorType 设置)和 Transaction 对象创建 Executor 对象。Executor 负责执行 SQL 语句,并处理缓存。
  4. 创建 DefaultSqlSession: 创建 DefaultSqlSession 对象,并将 ConfigurationExecutorautoCommit 标志(是否自动提交事务)传递给 DefaultSqlSession 的构造函数。
  5. 返回 DefaultSqlSession: openSession() 方法返回新创建的 DefaultSqlSession 对象。
    // DefaultSqlSessionFactory 的 openSessionFromDataSource() 方法 (简化版)
    private SqlSession openSessionFromDataSource(ExecutorType execType, TransactionIsolationLevel level, boolean autoCommit) {Transaction tx = null;try {final Environment environment = configuration.getEnvironment();final TransactionFactory transactionFactory = getTransactionFactoryFromEnvironment(environment);tx = transactionFactory.newTransaction(environment.getDataSource(), level, autoCommit);final Executor executor = configuration.newExecutor(tx, execType);return new DefaultSqlSession(configuration, executor, autoCommit);} catch (Exception e) {closeTransaction(tx); // may have fetched a connection so lets call close()throw ExceptionFactory.wrapException("Error opening session.  Cause: " + e, e);} finally {ErrorContext.instance().reset();}
    }
    

5. DefaultSqlSession:

  • DefaultSqlSessionSqlSession 接口的默认实现类。
  • 它包含了执行 SQL 语句、获取 Mapper 接口实例、管理事务等方法。
  • DefaultSqlSession 内部持有 Configuration 对象、Executor 对象和 autoCommit 标志。

总结:

MyBatis 创建 SqlSession 对象的过程如下:

  1. SqlSessionFactoryBuilder 构建 SqlSessionFactory (通常是 DefaultSqlSessionFactory)。
  2. 调用 SqlSessionFactoryopenSession() 方法。
  3. DefaultSqlSessionFactory 创建 TransactionExecutorDefaultSqlSession 对象。
  4. openSession() 方法返回 DefaultSqlSession 对象。

SqlSessionFactorySqlSession 的工厂,DefaultSqlSessionFactorySqlSessionFactory 的默认实现,DefaultSqlSessionSqlSession 的默认实现。SqlSessionFactoryBuilder 用于构建 SqlSessionFactory


http://www.ppmy.cn/news/1579707.html

相关文章

【Qt】qApp简单介绍

1. 介绍 在Qt中,qApp是一个全局指针,它指向当前的QApplication或QGuiApplication对象。这个全局指针在Qt应用程序中非常有用,因为它可以让你在任何地方访问到应用程序对象。 在C中,全局指针是一个可以在程序的任何地方访问的指针…

基于ESP32的桌面小屏幕实战[8]:任务创建

调用任务创建必须要添加下面两个头文件: #include "freertos/FreeRTOS.h" #include "freertos/task.h"还要定义一个静态的任务函数 static void test_task_example(void* arg) {for(;;) {vTaskDelay(1000 / portTICK_PERIOD_MS);printf("…

ChatGPT、DeepSeek、Grok 三者对比:AI 语言模型的博弈与未来

📝个人主页🌹:一ge科研小菜鸡-CSDN博客 🌹🌹期待您的关注 🌹🌹 1. 引言 随着人工智能技术的飞速发展,AI 语言模型已经成为人机交互、内容创作、代码生成、智能问答等领域的重要工具…

Docker 端口映射的 “隐藏炸弹“ 与安全访问方案

📌 问题描述 在启动 Docker 容器时,使用 -p 3001:3001 端口映射后,发现: 防火墙规则(firewalld、ufw)中看不到 3001 端口,但外部仍然可以访问!iptables 规则被 Docker 自动修改&am…

多种注意力机制(文本->残差->视频)

1.初代自我注意机制(多头注意力机制) 1.1原理 总体架构 上图是 Self-Attention 的结构,在计算的时候需要用到矩阵Q(查询),K(键值),V(值)。在实际中,Self-Attention 接收的是输入(单词的表示向量x组成的矩阵X) 或者上一个 Encoder block 的输出。而Q,K,…

后端主流数据库分析

一、关系型数据库(RDBMS) 1. MySQL:金融支付系统核心 行业场景:​ 金融支付:银行交易流水、支付订单(ACID事务保障)。​电商平台:商品库存管理、订单状态跟踪(高并发OLTP)。SaaS服务:多租户用户管理(分库分表隔离数据)。Python实战代码: # 金融交易事务操作(…

用Python实现持续集成与部署(CI/CD)流程:自动化测试、构建与部署

《Python OpenCV从菜鸟到高手》带你进入图像处理与计算机视觉的大门! 解锁Python编程的无限可能:《奇妙的Python》带你漫游代码世界 在现代软件开发中,持续集成与持续部署(CI/CD)已成为提高开发效率、确保代码质量的关键实践。本文将详细介绍如何使用Python编写CI/CD脚本…

[IP]RGMII

ETH_RGMII是一个网口IP,接口为RGMII类型 包含MAC,ARP,UDP等模块,用户接口为axis。 IP界面 信号定义 、 IP 使用要求 IP须在Vivado 2024.1及以上版本使用! Q/871128330 下载测试使用(含测试工程)