什么是MyBatis?
MyBatis 是一个优秀的持久层框架,它消除了几乎所有的 JDBC 代码和手动设置参数以及获取结果集的工作。MyBatis 使用简单的 XML 或注解用于配置和原始映射,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。
以下是关于 MyBatis 的详细全面介绍:
1. MyBatis 的历史
MyBatis 原本是 Apache 的一个开源项目 iBatis。2010年这个项目由 Apache Software Foundation 迁移到了 Google Code,并且改名为 MyBatis。后来,MyBatis 又迁移到了 GitHub。
2. MyBatis 的特点
灵活的映射规则:MyBatis 不会对应用程序或者数据库的现有设计强加任何影响。SQL 语句被用来映射到一些对象上,而不是将 Java 对象映射成数据库表格。
易于上手和使用:MyBatis 的 SQL 依赖于注解或简单的 XML 配置文件,易于理解和修改。
松耦合:MyBatis 不会像一些完全的 ORM 框架那样强迫你使用某种编程模型,你可以自由地使用 SQL。
强大的动态 SQL:MyBatis 提供了强大的动态 SQL 功能,可以动态地构建复杂的 SQL 语句。
支持各种数据库:MyBatis 支持多种数据库,如 MySQL、Oracle、SQL Server、DB2 等。
3. MyBatis 的核心组件
SqlSession:作为 MyBatis 工作的主要顶层 API,表示和数据库的一次会话,可以直接运行映射的 SQL 语句。
Executor:MyBatis 的核心接口,它里面有各种方法来执行你在映射文件里定义的 SQL 语句。
SqlSessionFactory:创建 SqlSession 的工厂类。
SqlSessionTemplate:MyBatis-Spring 的核心类,用于管理 MyBatis 的 SqlSession。
Mapper:Mapper 是一个接口,没有实现类,但是 MyBatis 会为这个接口生成一个代理对象。
4. MyBatis 的工作流程
读取配置文件:MyBatis 首先读取配置文件(mybatis-config.xml),配置文件中包含了数据库连接信息和映射文件的位置。
创建 SqlSessionFactory:通过配置文件的信息创建 SqlSessionFactory 对象。
创建 SqlSession:通过 SqlSessionFactory 打开一个新的 SqlSession。
执行 SQL 语句:SqlSession 对象包含了面向数据库执行 SQL 命令所需的所有方法,可以通过 SqlSession 实例直接运行映射的 SQL 语句。
返回结果:MyBatis 会将 SQL 执行结果映射成 Java 对象并返回。
关闭 SqlSession:操作完成后需要关闭 SqlSession。
5. MyBatis 的配置
MyBatis 的配置主要包括以下部分:
environments:配置数据库连接信息,包括数据源和事务管理器。
typeAliases:为 Java 类型设置别名,简化映射文件中的引用。
mappers:指定映射 SQL 映射文件的位置。
6. MyBatis 的映射文件
映射文件包含了 SQL 语句和映射规则,它的主要元素包括:
select:查询语句。
insert:插入语句。
update:更新语句。
delete:删除语句。
resultMap:定义结果集和对象之间的映射关系。
7. MyBatis 的动态 SQL
MyBatis 提供了动态 SQL 的支持,可以在 XML 映射文件内使用动态 SQL 语言,包括:
if:条件判断。
choose (when, otherwise):类似于 Java 中的 switch 语句。
trim (where, set):处理 SQL 语句中的 where 和 set 子句。
foreach:迭代集合。
MyBatis 通过这些功能,为 Java 应用程序提供了灵活、高效的数据持久化解决方案。