MyBatis之核心对象与工作流程及SqlSession操作

目录

[1. 📦MyBatis核心对象及工作流程](#1. 📦MyBatis核心对象及工作流程)

​编辑

[1.1. 🎯MyBatis 4个核心对象](#1.1. 🎯MyBatis 4个核心对象)

[1.2. 🕹️MABatis工作流程](#1.2. 🕹️MABatis工作流程)

[2. 📝使用SqlSession操作数据库初体验](#2. 📝使用SqlSession操作数据库初体验)

[2.1. 读取核心配置文件](#2.1. 读取核心配置文件)

[2.2. 创建SqlSessionFactoryBuilder对象](#2.2. 创建SqlSessionFactoryBuilder对象)

[2.3. 使用SqlSessionFactoryBuilder获取SqlSessionFactory对象](#2.3. 使用SqlSessionFactoryBuilder获取SqlSessionFactory对象)

[2.4. SqlSessionFactory对象获取SqlSession对象](#2.4. SqlSessionFactory对象获取SqlSession对象)

[2.5. 使用SqlSession直接操作数据库](#2.5. 使用SqlSession直接操作数据库)

[2.6. 关闭资源](#2.6. 关闭资源)

[3. ✨总结](#3. ✨总结)


💡【开发哲学共勉】

像 MyBatis 拆分 Builder/Factory/Session 一样,把大问题拆成只做一件事的小模块

🎉 前言

本节来讲解一下MyBatis核心对象和工作流程及使用SQLSession来操作数据库,旨在帮助大家更好的理解和掌握相关的知识(๑•̀ㅂ•́)و✧

个人主页:艺杯羹 🌿

系列专栏:MyBatis🚀

1. 📦MyBatis核心对象及工作流程

先看流程图,看完下面的讲解内容,再回过来看,就豁然开朗了(๑•̀ㅂ•́)و✧

1.1. 🎯MyBatis 4个核心对象

  1. SqlSessionFactoryBuilder

    可以理解成一个工厂的建造者,可以来创建工厂 --- SqlSessionFactory

  2. SqlSessionFactory

    可以理解成一个工厂,可以来生产SqlSession对象

  3. SqlSession

    1. 可以操作数据库

    2. 也可以创造Mapper代理对象操作数据库

  4. Mapper

    持久层接口的代理对象,实现持久层接口,来操作数据库

对象名称 理解类比 核心功能描述
SqlSessionFactoryBuilder 工厂建造者 负责创建 SqlSessionFactory 工厂,如同建筑师按图纸搭建工厂框架,仅在初始化时使用一次
SqlSessionFactory 数据库会话工厂 作为生产 SqlSession 的工厂,统一管理数据库连接配置,以单例模式存在,贯穿项目生命周期
SqlSession 数据库操作会话 直接执行 SQL 语句操作数据库,可管理事务;也能创建 Mapper 代理对象,是与数据库交互的核心接口
Mapper 持久层接口代理对象 实现持久层接口的动态代理,将接口方法映射为 SQL 操作,无需手写 SQL 即可完成数据库交互

它的工作流程也和上面介绍的这个顺序是一样的

1.2. 🕹️MABatis工作流程

  1. 创建 SqlSessionFactoryBuilder 对象(创建工程的建造者)

  2. SqlSessionFactoryBuilder 对象创建SqlSessionFactory (建造工程,成为建造者模式)

  3. SqlSessionFactory 对象生产了 SqlSession 对象:工厂模式

  4. SqlSession 对象创建了持久层接口的代理对象:动态代理模式

  5. 代理对象 Mapper操作数据库

现在可以回过去看看,工作的流程图,就能看懂了

2. 📝使用SqlSession操作数据库初体验

上面提到了可以使用代理对象Mapper获取对象,也可以SqlSession来获取对象,这种用的比较少那么先来看看SqlSession是如何获取对象的

2.1. 读取核心配置文件

java 复制代码
InputStream is = Resources.getResourceAsStream("SqlMapConfig.xml");

2.2. 创建SqlSessionFactoryBuilder对象

java 复制代码
SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();

2.3. 使用SqlSessionFactoryBuilder获取SqlSessionFactory对象

java 复制代码
SqlSessionFactory factory = builder.build(is);

2.4. SqlSessionFactory对象获取SqlSession对象

java 复制代码
SqlSession session = factory.openSession();

2.5. 使用SqlSession直接操作数据库

java 复制代码
List<User> users = session.selectList("com.yibeigen.mapper.UserMapper.findAll");
// 输出
users.forEach(System.out::println);

2.6. 关闭资源

java 复制代码
session.close();
is.close();

完整代码

java 复制代码
@Test
public void testFindAll2() throws Exception {
  // (1)读取核心配置文件
  InputStream is = Resources.getResourceAsStream("SqlMapConfig.xml");
  // (2)创建SqlSessionFactoryBuilder对象
  SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
  // (3)SqlSessionFactoryBuilder对象获取SqlSessionFactory对象
  SqlSessionFactory factory = builder.build(is);
  // (4)SqlSessionFactory对象获取SqlSession对象
  SqlSession session = factory.openSession();
  // (5)SqlSession直接操作数据库
  List<User> users = session.selectList("com.yibeigen.mapper.UserMapper.findAll");
  users.forEach(System.out::println);
  // (6)关闭资源
  session.close();
  is.close();
}

3. ✨总结

MyBatis核心对象和工作流程及sqlsession讲解就到此结束了,希望对你有所帮助😊

相关推荐
程序员小凯21 小时前
Spring Boot文件处理与存储详解
java·spring boot·后端
Miraitowa_cheems1 天前
LeetCode算法日记 - Day 88: 环绕字符串中唯一的子字符串
java·数据结构·算法·leetcode·深度优先·动态规划
黑云压城After1 天前
vue2实现图片自定义裁剪功能(uniapp)
java·前端·javascript
zcl_19911 天前
记一次ThreadLocal导致的生产事故
java
RoboWizard1 天前
怎么判断我的电脑是否支持PCIe 5.0 SSD?Kingston FURY Renegade G5
java·spring·智能手机·电脑·金士顿
毕设源码-钟学长1 天前
【开题答辩全过程】以 儿童游泳预约系统为例,包含答辩的问题和答案
java·eclipse
皮皮林5511 天前
5种接口频率监控方案实战对比,性能、成本、复杂度全解析!
java
似水流年 光阴已逝1 天前
从Jar包到K8s上线:全流程拆解+高可用实战
java·kubernetes·jar
YA3331 天前
java设计模式八、组合模式
java·设计模式·组合模式
一枚码仔1 天前
SpringBoot启动时执行自定义内容的5种方法
java·spring boot·后端