【Mytais系列】介绍、核心概念

MyBatis 是一款优秀的 持久层框架,它通过简化 JDBC 操作、提供灵活的 SQL 映射能力,成为 Java 开发中处理数据库交互的核心工具之一。以下是 MyBatis 的核心框架和概念解析:


一、MyBatis 框架概述

1. 核心定位
  • 作用:将 Java 对象与 SQL 语句解耦,通过 XML 或注解配置 SQL,自动完成参数映射和结果集转换。
  • 优势
    • 灵活控制 SQL:直接编写 SQL,适合复杂查询和性能优化场景。
    • 轻量级:无需依赖完整的 ORM 框架,学习成本低。
    • 与 Spring 无缝整合:通过 mybatis-spring 模块简化集成。
2. 与其他 ORM 的对比
  • Hibernate
    • Hibernate 强调全自动 ORM(对象-表映射),适合快速开发;
    • MyBatis 更注重 SQL 灵活性,适合需要手动优化 SQL 的场景。
  • JDBC
    • MyBatis 封装了 JDBC 的冗余代码(如连接管理、结果集遍历),开发者只需关注 SQL 本身。

二、MyBatis 核心概念

1. 核心组件
  • SqlSessionFactory
    • 作用:全局单例工厂,用于创建 SqlSession
    • 创建过程:通过解析 mybatis-config.xml 配置文件,构建 Configuration 对象(包含所有配置信息)。
    • 代码示例
InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
  • SqlSession
    • 作用:代表一次数据库会话,用于执行 SQL 并获取 Mapper 接口。
    • 特性非线程安全,需确保每次请求创建一个实例,用后关闭。
    • 常用方法
User user = sqlSession.selectOne("com.example.mapper.UserMapper.selectUser", 1);
sqlSession.commit(); // 提交事务
sqlSession.close();  // 关闭会话
  • Mapper 接口
    • 原理:通过 动态代理 将接口方法与 XML 或注解中的 SQL 绑定。
    • 示例
public interface UserMapper {@Select("SELECT * FROM user WHERE id = #{id}")User selectUser(int id);
}
2. 配置文件
  • 全局配置文件(mybatis-config.xml
    • 配置数据源、事务管理器、插件、类型处理器等全局设置。
    • 示例片段
<configuration><environments default="development"><environment id="development"><transactionManager type="JDBC"/><dataSource type="POOLED"><property name="driver" value="com.mysql.jdbc.Driver"/><property name="url" value="jdbc:mysql://localhost:3306/test"/><property name="username" value="root"/><property name="password" value="root"/></dataSource></environment></environments><mappers><mapper resource="com/example/mapper/UserMapper.xml"/></mappers>
</configuration>
  • Mapper XML 文件
    • 定义 SQL 语句、结果映射(<resultMap>)、动态 SQL 等。
    • 示例片段
<mapper namespace="com.example.mapper.UserMapper"><select id="selectUser" resultType="User">SELECT * FROM user WHERE id = #{id}</select>
</mapper>

三、核心工作流程

  1. 初始化阶段
    • 解析 mybatis-config.xml 和所有 Mapper XML,构建 Configuration 对象。
    • 创建 SqlSessionFactory
  1. 执行阶段
    • 通过 SqlSessionFactory 创建 SqlSession
    • SqlSession 获取 Mapper 接口的代理对象(MapperProxy)。
    • 代理对象将方法调用转发给 SqlSession,执行对应的 SQL。
  1. SQL 执行过程
    • Executor:执行 SQL,处理缓存(一级缓存)。
    • StatementHandler:构建 PreparedStatement,设置参数。
    • ResultSetHandler:将结果集转换为 Java 对象。

四、关键特性

1. 动态 SQL
  • 作用:根据条件动态拼接 SQL,避免手动拼接字符串。
  • 常用标签
<select id="findUsers">SELECT * FROM users<where><if test="name != null">AND name = #{name}</if><if test="age != null">AND age > #{age}</if><foreach item="id" collection="ids" open="AND id IN (" separator="," close=")">#{id}</foreach></where>
</select>
2. 结果映射(ResultMap)
  • 作用:处理复杂对象与数据库字段的映射(如嵌套对象、集合)。
  • 示例
<resultMap id="userResultMap" type="User"><id property="id" column="user_id"/><result property="name" column="user_name"/><collection property="orders" ofType="Order"><result property="orderId" column="order_id"/></collection>
</resultMap>
3. 缓存机制
  • 一级缓存:默认开启,基于 SqlSession 生命周期,执行更新操作后失效。
  • 二级缓存:需手动配置,基于 namespace 级别,跨会话共享(需序列化)。

五、适用场景

  • 复杂 SQL 需求:需要手动优化 SQL 性能的场景(如大数据量分页、多表关联查询)。
  • 遗留系统改造:已有复杂 SQL 的系统,迁移到 MyBatis 成本较低。
  • 对 SQL 可控性要求高:开发团队希望直接控制 SQL 而非依赖框架生成。

总结

MyBatis 的核心在于 平衡灵活性与开发效率,通过简化 JDBC 操作、提供动态 SQL 和结果映射能力,成为处理复杂数据库交互的理想选择。掌握其核心组件(如 SqlSessionMapper)、配置方式及动态 SQL 机制,是高效使用 MyBatis 的关键。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/79572.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

IO模型和多路复用

一、IO模型的基础理解 什么是IO? IO全称是 Input/Output(输入/输出),在计算机科学里主要指程序与外部设备(硬盘、网络、用户终端等)进行数据交换的操作。首要特点是: IO通常很慢(从CPU和内存的视角看)经常需要等待外部设备响应1. 为什么要谈IO模型? 当一个程序需要…

深入理解 Bash 中的 $‘...‘ 字符串语法糖

在 Bash 脚本编程中&#xff0c;字符串处理是不可或缺的一部分。为了让开发者更高效地处理特殊字符和控制字符&#xff0c;Bash 引入了一种独特的字符串语法糖&#xff1a;$&#xff08;带单引号的 ANSI-C 风格字符串&#xff09;。这种语法来源于 C 语言的 ANSI-C 标准&#x…

用Python打造自己的专属命令行工具

在日常的开发和使用过程中&#xff0c;我们常常会编写一些实用的Python脚本&#xff0c;比如用来批量处理文件、获取系统信息等。然而&#xff0c;每次都要输入python script_name.py来运行脚本&#xff0c;时间一长难免觉得繁琐。要是能像使用系统自带的命令&#xff08;如ls、…

【KWDB 创作者计划】KWDB 2.2.0多模融合架构与分布式时序引擎

KWDB介绍 KWDB数据库是由开放原子开源基金会孵化的分布式多模数据库&#xff0c;专为AIoT场景设计&#xff0c;支持时序数据、关系数据和非结构化数据的统一管理。其核心架构采用多模融合引擎&#xff0c;集成列式时序存储、行式关系存储及自适应查询优化器&#xff0c;实现跨模…

学习Linux的第二天

如何在Linux环境下做开发 Linux的一些基操 Tips&#xff1a;平常最表层的是命令行模式&#xff0c;最多见这个默认叫做命令行模式 Vi操作是什么意思呢 就是在提示符输入vi a.c 是可以创建一个a.c这个文件并进入这个输入模式 按i可以输入代码 要退出的时候按esc 再按:(冒号…

链表操作练习

要求 现在有一个双向链表&#xff0c;里面要保存歌曲的名字&#xff1b;例如 蔡琴/渡口.mp3 我们把它定义在一个link.h文件中。 #ifndef LINK_H #define LINK_H #include <stdlib.h> #include <stdio.h> #include <string.h>typedef struct Node {//保存歌…

MATLAB制作散点图:从基础到进阶的三种类型讲解

一、什么是散点图 散点图是一种用来展示两个或多个变量之间关系的图表形式。它可以帮助我们直观地观察变量之间是否存在相关性、趋势或异常值&#xff0c;常用于数据分析的初步探索阶段。 二、三种类型散点图 1. 基本二维散点图&#xff1a;最简单、最常用 基本二维散点图的…

模块方法模式(Module Method Pattern)

&#x1f9e0; 模块方法模式&#xff08;Module Method Pattern&#xff09; 模块方法模式是一种结构型设计模式&#xff0c;它将复杂的操作分解成一系列相对简单、独立且单一职责的模块。每个模块负责完成一种具体的操作&#xff0c;其他模块或系统可以通过调用这些模块的公开…

Python中的JSON库,详细介绍与代码示例

目录 1. 前言 2. json 库基本概念 3. json 的适应场景 4. json 库的基本用法 4.1 导 json入 模块 4.2 将 Python 对象转换为 JSON 字符串 4.3 将 JSON 字符串转换为 Python 对象 4.4 将 Python 对象写入 JSON 文件 4.5 从 JSON 文件读取数据 4.6 json 的其他方法 5.…

网狐旗舰大联盟组件源码私测笔记:结构分层、UI重构与本地实操全流程

作为一套衍生于传统网狐架构的源码版本&#xff0c;大联盟这套源码组件可谓是在经典基础上进行了深度重塑。与老版死板的框架风格不同&#xff0c;它不仅对界面做了大刀阔斧的重构&#xff0c;还在组件层级的组织上做了优化。本文将基于一整套源码进行深度解析&#xff0c;强调…

STM32 PulseSensor心跳传感器驱动代码

STM32CubeMX中准备工作&#xff1a; 1、设置AD 通道 2、设置一个定时器中断&#xff0c;间隔时间2ms&#xff0c;我这里采用的是定时器7 3、代码优化01 PulseSensor.c文件 #include "main.h" #include "PulseSensor/PulseSensor.h"/******************…

C++项目容易犯错的点

1. 矩阵q要先定义大小&#xff0c;再赋值。不可以直接赋值。下面这种方式是错误的Eigen::MatrixXd q&#xff1b;q<<1,2&#xff1b;正确的这样的&#xff1a; Eigen::MatrixXd q(2,1); q<<1.4, 1.5; 2. 不要重复加载variables.h头文件&#xff0c;这样变量会被…

在阿里云 Ubuntu 24.04 上部署 RabbitMQ:一篇实战指南

前言 RabbitMQ 是业界常用的开源消息中间件,支持 AMQP 协议,易于部署、高可用、插件丰富。本文以阿里云 ECS 上运行的 Ubuntu 24.04 LTS 为例,手把手带你完成 RabbitMQ 从仓库配置到运行的全流程,并分享在国内环境下常见的坑与对应解决方案。 环境概况 操作系统:Ubuntu …

【论文笔记】SOTR: Segmenting Objects with Transformers

【题目】&#xff1a;SOTR: Segmenting Objects with Transformers 【引用格式】&#xff1a;Guo R, Niu D, Qu L, et al. Sotr: Segmenting objects with transformers[C]//Proceedings of the IEEE/CVF international conference on computer vision. 2021: 7157-7166. 【网…

MinIO实现https访问

Windows下实现MinIO的https访问. 首先需要自己解决证书问题, 这里可以是个人证书 也可以是花钱买的证书. 现在使用个人开发者证书举例子。 将证书数据解压到你知道的目录之下 然后直接使用命令启动MinIO start minio.exe server --certs-dir D:\xxxxx\tools\certs …

基于 jQuery 实现灵活可配置的输入框验证功能

在 Web 表单开发中&#xff0c;输入框验证是保障数据准确性和安全性的关键环节。无论是用户注册、信息提交还是数据录入场景&#xff0c;都需要对用户输入内容进行合法性检查。本文将介绍如何使用 HTML、CSS 和 jQuery 构建一个可灵活配置的输入框验证系统&#xff0c;轻松应对…

Kotlin 04Flow stateIn 和 shareIn的区别

一 Kotlin Flow 中的 stateIn 和 shareIn 一、简单比喻理解 想象一个水龙头&#xff08;数据源&#xff09;和几个水杯&#xff08;数据接收者&#xff09;&#xff1a; 普通 Flow&#xff08;冷流&#xff09;&#xff1a;每个水杯来接水时&#xff0c;都要重新打开水龙头从…

WebRTC 服务器之SRS服务器概述和环境搭建

1.概述 SRS&#xff08;Simple Realtime Server&#xff09;是一款高性能、跨平台的流媒体服务器&#xff0c;支持多种协议&#xff0c;包括 RTMP、WebRTC、HLS、HTTP-FLV、SRT、MPEG-DASH 和 GB28181。本文介绍了 SRS&#xff0c;包括其用途、关键功能、架构和支持协议。SRS 旨…

Dify - Embedding Rerank

注意&#xff1a;v100显卡会出现不适配&#xff0c;不推荐使用 1. 安装 Docker ubuntu 22.04 docker 安装&使用_ubuntu22.04 安装docker-CSDN博客 2. 安装vllm pip install -U xformers torch torchvision torchaudio triton --index-url https://download.pytorch.org/w…

LeetCode:链表的中间结点

1、题目描述 给你单链表的头结点 head &#xff0c;请你找出并返回链表的中间结点。 如果有两个中间结点&#xff0c;则返回第二个中间结点。 示例 1&#xff1a; 输入&#xff1a;head [1,2,3,4,5] 输出&#xff1a;[3,4,5] 解释&#xff1a;链表只有一个中间结点&#xff…