Mybatis自学笔记:详尽配置与使用技巧
版权申诉
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具有重要的参考价值。
522 浏览量
258 浏览量
106 浏览量
276 浏览量
231 浏览量
2020-12-21 上传
110 浏览量
111 浏览量
115 浏览量
天堂不能没有你
- 粉丝: 97
- 资源: 12
最新资源
- java文本比较器.rar
- 传输线:使用Phaser制作的2018年全球Game Jam游戏
- MechaCar_Statistical_Analysis
- OCR文字识别.rar
- matlab代码做游戏-One::scissors::clipboard:精选的超赞列表
- 凝结顺序
- DiscGolf:飞盘高尔夫网站
- vue-phaser-starter:一个游戏入门项目,使用Phaser,Vue,ES6,Webpack
- ZFPlayer:支持任何播放器SDK和控制层的自定义(支持定制任何播放器SDK和控制层)
- GridTreeCtrl.7z
- mysql-5.6.13-winx64.zip
- noteful-server
- cargamos_test
- xcom串口调试助手2.5+2.0..rar
- phaser-3-snake-game:基于Phaser World#85发布的“ Snake Plissken”教程的Phaser 3演示项目
- 三菱FR-A500系列变频器资料.rar