Mybatis自学笔记:详尽配置与使用技巧

版权申诉
0 下载量 96 浏览量 更新于2024-10-06 收藏 19KB RAR 举报
资源摘要信息: "mybatis学习项目笔记" Mybatis是一个优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射。Mybatis避免了几乎所有的JDBC代码和手动设置参数以及获取结果集。Mybatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJOs(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录。 ### 1. Mybatis核心组件 - **SqlSessionFactory**:SqlSessionFactory是Mybatis的核心组件,用于创建SqlSession。它是单个数据库映射关系经过编译后的内存镜像。 - **SqlSession**:代表和数据库交互的会话。通过SqlSession可以执行命令,获取映射器和提交或回滚事务。 - **MappedStatement**:由配置文件中的一个SQL映射语句所转换成的内化对象,它包含了一个SQL语句、结果映射信息、缓存信息等。 - **Executor**:是Mybatis的内部组件,负责SQL语句的生成和查询缓存的维护。 - **StatementHandler**:负责对JDBC Statement对象的创建和设置参数。 - **ParameterHandler**:负责对用户传递的参数转换成JDBC Statement所使用的参数。 - **ResultSetHandler**:负责将JDBC返回的ResultSet结果集对象转换成Java对象。 ### 2. Mybatis配置文件 Mybatis的配置文件是mybatis-config.xml,其中包含了对Mybatis进行系统全局配置的信息,包括数据库连接池信息、事务管理器、映射文件的位置等。配置文件中常见的标签有: - `<environments>`:配置数据库连接环境。 - `<transactionManager>`:配置事务管理器。 - `<dataSource>`:配置数据源连接池。 - `<mappers>`:配置映射器,用于加载SQL映射文件。 ### 3. Mybatis映射文件 映射文件是Mybatis的核心之一,它将SQL语句与Java对象建立映射关系,包含了一组映射语句,每个映射语句被称作MappedStatement。映射文件中的常见元素包括: - `<insert>`、`<update>`、`<delete>`、`<select>`:定义了对应数据库操作的SQL语句。 - `<resultMap>`:自定义结果集映射规则。 - `<parameterMap>`:自定义参数映射规则(已基本被注解取代)。 ### 4. Mybatis动态SQL Mybatis支持动态SQL,可以根据不同的条件生成不同的SQL语句,提高开发的灵活性和效率。Mybatis提供了多种动态SQL标签,如: - `<if>`:根据条件判断是否需要拼接SQL片段。 - `<choose>`、`<when>`、`<otherwise>`:相当于Java中的switch-case语句,进行条件选择。 - `<where>`、`<set>`:用于简化WHERE和SET条件的拼接。 - `<foreach>`:用于遍历集合,常用于IN条件查询。 - `<bind>`:用于创建一个变量并给变量赋值,可以用于动态SQL的其他部分。 ### 5. Mybatis与Spring整合 Mybatis与Spring框架整合使用时,可以通过Spring配置文件或注解方式注入SqlSessionFactory,从而简化数据库操作的代码。在Spring中,Mybatis的操作通常封装在Mapper接口中,通过SqlSessionTemplate来执行这些操作。 ### 6. Mybatis缓存机制 Mybatis拥有两级缓存机制: - 一级缓存:作用域为SqlSession,当SqlSession关闭或者调用clearCache()时,缓存会被清空。一级缓存是默认开启的,主要用于避免对数据库进行重复查询。 - 二级缓存:作用域为SqlSessionFactory,可以跨SqlSession共享数据。二级缓存是可选配置,需要在Mapper映射文件或接口中声明开启。通常情况下,二级缓存中存放的是结果集的缓存。 ### 7. Mybatis拦截器 Mybatis拦截器(Interceptor)是Mybatis提供的一个用于扩展和自定义Mybatis功能的接口。通过实现Interceptor接口并重写其中的几个方法,可以对Executor、StatementHandler、ParameterHandler、ResultSetHandler进行拦截,从而实现自定义的SQL拦截功能,例如分页插件、性能分析插件等。 ### 8. Mybatis注解 除了XML配置方式,Mybatis还支持通过注解的方式进行配置,这使得Mybatis的使用更为简便。常见的注解包括: - `@Select`、`@Insert`、`@Update`、`@Delete`:分别用于对应SQL语句的注解。 - `@Results`、`@Result`:用于自定义结果集的映射规则。 - `@Param`:用于在方法参数中传递多个参数。 以上知识点涵盖了Mybatis的基本使用方法和高级特性,涵盖了配置、映射、动态SQL、与Spring的整合、缓存机制、拦截器以及注解等方面的深入理解,对于学习Mybatis具有重要的参考价值。