什么是 MyBatis?

文章目录

    • [1️⃣ MyBatis 简介](#1️⃣ MyBatis 简介)
      • [📌 MyBatis 主要特点](#📌 MyBatis 主要特点)
    • [2️⃣ MyBatis vs 传统 JDBC vs Hibernate 📊](#2️⃣ MyBatis vs 传统 JDBC vs Hibernate 📊)
    • [3️⃣ MyBatis 核心组件 🏗️](#3️⃣ MyBatis 核心组件 🏗️)
      • [1. SqlSessionFactory](#1. SqlSessionFactory)
      • [2. SqlSession](#2. SqlSession)
      • [3. Mapper(映射器)](#3. Mapper(映射器))
    • [4️⃣ MyBatis 配置文件结构 📂](#4️⃣ MyBatis 配置文件结构 📂)
      • [📌 `mybatis-config.xml` 示例](#📌 mybatis-config.xml 示例)
      • [📌 `UserMapper.xml` 示例](#📌 UserMapper.xml 示例)
    • [5️⃣ MyBatis 的典型使用流程 🔄](#5️⃣ MyBatis 的典型使用流程 🔄)
    • [6️⃣ 适用场景与总结 🎯](#6️⃣ 适用场景与总结 🎯)

1️⃣ MyBatis 简介

MyBatis 是一款优秀的 持久层框架 ,用于简化 Java 应用程序与数据库的交互。它提供了一种 基于 SQL 映射 的持久化方案,避免了 JDBC 繁琐的代码,同时比全自动的 ORM 框架(如 Hibernate)更灵活。

📌 MyBatis 主要特点

  • SQL 映射:开发者可以手写 SQL,更加灵活,适用于复杂查询。
  • 简化 JDBC:封装了数据库连接、参数设置、结果映射等步骤。
  • 动态 SQL :支持 ifchooseforeach 等标签,使 SQL 更具适应性。
  • 缓存机制:内置一级缓存和可选的二级缓存,提高查询效率。
  • 插件扩展:可自定义拦截器,增强 SQL 执行逻辑。

2️⃣ MyBatis vs 传统 JDBC vs Hibernate 📊

特性 JDBC MyBatis Hibernate
开发复杂度 需手写 SQL,较复杂 需手写 SQL,较灵活 无需手写 SQL,自动映射
SQL 控制 完全手动控制 手写 SQL,可动态 SQL 由框架生成,难以优化
性能 可优化,但代码冗长 适中,SQL 直接执行 可能存在 N+1 查询问题
缓存机制 无内置缓存 一级、二级缓存支持 一级、二级缓存 + JPA 级联缓存
学习成本 低,但需处理大量重复代码 适中,需要理解 XML 或注解映射 高,需要学习 HQL、映射配置

总结:如果项目对 SQL 有高度控制需求,且查询较复杂,MyBatis 是一个很好的选择。


3️⃣ MyBatis 核心组件 🏗️

1. SqlSessionFactory

  • 作用 :创建 SqlSession,管理数据库连接。

  • 示例代码:

    java 复制代码
    InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");
    SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

2. SqlSession

  • 作用:执行 SQL 语句,管理事务。

  • 示例代码:

    java 复制代码
    try (SqlSession session = sqlSessionFactory.openSession()) {
        User user = session.selectOne("com.example.mapper.UserMapper.selectUser", 1);
    }

3. Mapper(映射器)

  • 作用:定义 SQL 语句的接口,MyBatis 会动态生成实现类。

  • 示例代码:

    java 复制代码
    public interface UserMapper {
        @Select("SELECT * FROM users WHERE id = #{id}")
        User selectUser(int id);
    }

4️⃣ MyBatis 配置文件结构 📂

MyBatis 使用 XML 或 Java 代码进行配置,主要包含以下部分:

  • mybatis-config.xml(核心配置)
  • mapper.xml(SQL 映射文件)

📌 mybatis-config.xml 示例

xml 复制代码
<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/test"/>
                <property name="username" value="root"/>
                <property name="password" value="123456"/>
            </dataSource>
        </environment>
    </environments>
</configuration>

📌 UserMapper.xml 示例

xml 复制代码
<mapper namespace="com.example.mapper.UserMapper">
    <select id="selectUser" resultType="com.example.model.User">
        SELECT * FROM users WHERE id = #{id}
    </select>
</mapper>

5️⃣ MyBatis 的典型使用流程 🔄

1️⃣ 加载 MyBatis 配置文件,创建 SqlSessionFactory

2️⃣ 获取 SqlSession,执行 SQL 语句

3️⃣ 使用 Mapper 进行数据库操作

4️⃣ 提交事务(openSession(true) 自动提交)

5️⃣ 关闭 SqlSession,释放资源


6️⃣ 适用场景与总结 🎯

Mybatis适用于:

  • 需要 手写 SQL,优化查询性能的项目
  • 复杂数据库结构,ORM 框架难以满足需求的场景
  • 需要 轻量级持久层框架 的应用

不适用于:

  • 需要全自动 ORM,避免写 SQL 的项目(可以考虑 Hibernate)

🎯 总结 :MyBatis 结合了 SQL 的灵活性和 ORM 的便利性,适用于大多数 企业级应用

相关推荐
向哆哆7 分钟前
Java 微服务架构设计:服务拆分与服务发现的策略
java·微服务·服务发现
比特森林探险记12 分钟前
Go语言结构体:数据组织的艺术
开发语言·后端·golang
天天摸鱼的java工程师14 分钟前
Redis 是单线程的吗?带你全面了解 Redis 的线程模型与设计哲学
java·后端
天天摸鱼的java工程师15 分钟前
Spring Boot 3 整合 Knife4j:从环境搭建到 API 文档生成实战
java·后端
述雾学java29 分钟前
Spring Boot 整合 Spring Security
java·spring boot·spring security
风象南40 分钟前
SpringBoot解决依赖冲突的5个技巧
java·spring boot·后端
天天摸鱼的java工程师42 分钟前
优秀后端如何定义返回值?
java·后端
都叫我大帅哥42 分钟前
Java的synchronized:从入门到“秃头”的终极指南
java
琢磨先生David6 小时前
责任链模式:构建灵活可扩展的请求处理体系(Java 实现详解)
java·设计模式·责任链模式
-曾牛7 小时前
使用Spring AI集成Perplexity AI实现智能对话(详细配置指南)
java·人工智能·后端·spring·llm·大模型应用·springai