MyBatis 详解

     毕业之前就听说了springMVC和mybatis搭配,后来有机会在实际项目中接触了一下,于是乎,想把它整理一下,在网上简单查了一些资料,汇聚此篇!
     MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis 。
iBATIS一词来源于“internet”和“abatis”的组合,是一个基于Java的持久层框架。iBATIS提供的持久层框架包括SQL Maps和Data Access Objects(DAO)

1背景介绍

      MyBatis 是支持普通 SQL查询,存储过程和高级映射的优秀持久层框架。MyBatis 消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索。MyBatis 使用简单的 XML或注解用于配置和原始映射,将接口和 Java 的POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。
每个MyBatis应用程序主要都是使用SqlSessionFactory实例的,一个SqlSessionFactory实例可以通过SqlSessionFactoryBuilder获得。SqlSessionFactoryBuilder可以从一个xml配置文件或者一个预定义的配置类的实例获得。
用xml文件构建SqlSessionFactory实例是非常简单的事情。推荐在这个配置中使用类路径资源(classpath resource),但你可以使用任何Reader实例,包括用文件路径或file://开头的url创建的实例。MyBatis有一个实用类----Resources,它有很多方法,可以方便地从类路径及其它位置加载资源。

2总体流程

(1)加载配置并初始化
触发条件:加载配置文件
将SQL的配置信息加载成为一个个MappedStatement对象(包括了传入参数映射配置、执行的SQL语句、结果映射配置),存储在内存中。
(2)接收调用请求
触发条件:调用Mybatis提供的API
传入参数:为SQL的ID和传入参数对象
处理过程:将请求传递给下层的请求处理层进行处理。
(3)处理操作请求 触发条件:API接口层传递请求过来
传入参数:为SQL的ID和传入参数对象
处理过程:
(A)根据SQL的ID查找对应的MappedStatement对象。
(B)根据传入参数对象解析MappedStatement对象,得到最终要执行的SQL和执行传入参数。
(C)获取数据库连接,根据得到的最终SQL语句和执行传入参数到数据库执行,并得到执行结果。
(D)根据MappedStatement对象中的结果映射配置对得到的执行结果进行转换处理,并得到最终的处理结果。
(E)释放连接资源。
(4)返回处理结果将最终的处理结果返回

3功能架构

MyBatis架构

MyBatis架构

功能架构讲解:
我们把Mybatis的功能架构分为三层:
(1)API接口层:提供给外部使用的接口API,开发人员通过这些本地API来操纵数据库。接口层一接收到调用请求就会调用数据处理层来完成具体的数据处理。
(2)数据处理层:负责具体的SQL查找、SQL解析、SQL执行和执行结果映射处理等。它主要的目的是根据调用的请求完成一次数据库操作。
(3)基础支撑层:负责最基础的功能支撑,包括连接管理、事务管理、配置加载和缓存处理,这些都是共用的东西,将他们抽取出来作为最基础的组件。为上层的数据处理层提供最基础的支撑。

4框架架构

框架架构讲解:
(1)加载配置:配置来源于两个地方,一处是配置文件,一处是Java代码的注解,将SQL的配置信息加载成为一个
mybatis结构

mybatis结构

个MappedStatement对象(包括了传入参数映射配置、执行的SQL语句、结果映射配置),存储在内存中。
(2)SQL解析:当API接口层接收到调用请求时,会接收到传入SQL的ID和传入对象(可以是Map、JavaBean或者基本数据类型),Mybatis会根据SQL的ID找到对应的MappedStatement,然后根据传入参数对象对MappedStatement进行解析,解析后可以得到最终要执行的SQL语句和参数。
(3)SQL执行:将最终得到的SQL和参数拿到数据库进行执行,得到操作数据库的结果。
(4)结果映射:将操作数据库的结果按照映射的配置进行转换,可以转换成HashMap、JavaBean或者基本数据类型,并将最终结果返回

5动态SQL

        MyBatis 最强大的特性之一就是它的动态语句功能。如果您以前有使用JDBC或者类似框架的
经历,您就会明白把SQL语句条件连接在一起是多么的痛苦,要确保不能忘记空格或者不要在columns列后面省略一个逗号等。动态语句能够完全解决掉这些痛苦。
  尽管与动态SQL一起工作不是在开一个party,但是MyBatis确实能通过在任何映射SQL语句中
使用强大的动态SQL来改进这些状况。
  动态SQL元素对于任何使用过JSTL或者类似于XML之类的文本处理器的人来说,都是非常熟悉
的。在上一版本中,需要了解和学习非常多的元素,但在MyBatis 3 中有了许多的改进,现在只
剩下差不多二分之一的元素。MyBatis使用了基于强大的OGNL表达式来消除了大部分元素。

### MyBatis 详解:使用教程与原理介绍 #### 工作原理概述 MyBatis 是一种持久层框架,它支持定制化 SQL 查询、存储过程以及高级映射。其工作流程可以分为以下几个方面: - 配置文件解析阶段:MyBatis 加载 `mybatis-config.xml` 文件并初始化局配置信息[^3]。 - 动态 SQL 解析阶段:SQL 映射语句被加载到内存中,并根据参数动态生成最终执行的 SQL 语句。 - 数据库交互阶段:通过 JDBC 进行数据库操作,返回查询结果。 #### 开发环境搭建 要开始使用 MyBatis,需完成以下准备工作: - 导入 MyBatis 的核心 JAR 包作为项目的依赖项。如果采用 Maven 构建工具,则可以通过 POM 文件引入所需依赖[^2]。 ```xml <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.x.x</version> </dependency> ``` #### 局配置文件说明 (`mybatis-config.xml`) 此文件定义了 MyBatis 的运行环境及相关设置,主要包括数据源配置和事务管理器等内容。以下是典型的 XML 结构示例: ```xml <?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="${jdbc.driver}"/> <property name="url" value="${jdbc.url}"/> <property name="username" value="${jdbc.username}"/> <property name="password" value="${jdbc.password}"/> </dataSource> </environment> </environments> <!-- Mapper 扫描路径 --> <mappers> <mapper resource="com/example/mapper/UserMapper.xml"/> </mappers> </configuration> ``` #### SQL 映射文件设计 SQL 映射文件描述了如何将 Java 对象映射至数据库表中的记录。下面是一个简单的例子展示增删改查的操作方式: ```xml <mapper namespace="com.example.mapper.UserMapper"> <!-- 插入新用户 --> <insert id="addUser" parameterType="com.example.model.User"> INSERT INTO users (name, age) VALUES (#{name}, #{age}) </insert> <!-- 删除指定ID的用户 --> <delete id="removeUserById" parameterType="int"> DELETE FROM users WHERE id=#{id} </delete> <!-- 更新现有用户的属性 --> <update id="modifyUserInfo" parameterType="com.example.model.User"> UPDATE users SET name=#{name}, age=#{age} WHERE id=#{id} </update> <!-- 查找特定条件下的所有匹配条目 --> <select id="findUsersByAgeRange" resultType="com.example.model.User"> SELECT * FROM users WHERE age BETWEEN #{minAge} AND #{maxAge} </select> </mapper> ``` #### 编程接口调用方法 在实际编码过程中,通常会借助 MyBatis 提供的 SqlSession 来实现业务逻辑处理。例如: ```java import org.apache.ibatis.session.SqlSession; import com.example.mapper.UserMapper; public class UserService { private final UserMapper userMapper; public UserService(SqlSession sqlSession){ this.userMapper = sqlSession.getMapper(UserMapper.class); } public void addUser(String name,int age){ userMapper.addUser(name,age); // 调用对应的 insert 方法 } public List<User> findUsersInRange(int minAge,int maxAge){ return userMapper.findUsersByAgeRange(minAge,maxAge); // 返回符合条件的结果集 } } ``` #### 官方资源获取途径 对于希望深入研究该技术栈的学习者而言,可以从官方 GitHub 库下载最新版本及其文档资料[^4]: - 地址链接: https://github.com/mybatis/mybatis-3 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值