MyBatis本是Apache软件基金会的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了Google Code,并且改名为MyBatis 。2013年11月迁移到Github。
MyBatis是一个 优秀的基于Java的持久层框架,支持自定义SQL,存储过程和高级映射。
MyBatis 对原有JDBC操作进行了封装,几乎消除了所有JDBC代码,使开发者只需关注 SQL 本身。
MyBatis可以使用简单的XML或Annotation来配置执行SQL,并 自动完成ORM操作,将执行结果返回。
Maybatis入门案例
1.先构建一个Maven项目
2.在pom.xml中引入入Mybatis依赖
![](https://img-blog.csdnimg.cn/img_convert/38ea21679d0eff34177d8e4ebf652d92.png)
3.创建db.properties配置文件
![](https://img-blog.csdnimg.cn/img_convert/c53b9ff37fdefd03a5d69a38b53ad100.png)
4.创建log4j.properties配置文件
![](https://img-blog.csdnimg.cn/img_convert/01c4c8f94828a687bf9f82304d1b52ca.png)
5.创建mybatis-config.xml配置文件
在resources目录下创建
![](https://img-blog.csdnimg.cn/img_convert/02a215bac60e0fc5a1c8ecca621ecb08.png)
6.定义实体类
![](https://img-blog.csdnimg.cn/img_convert/579e8777a0fdb8068cd8cd20329a79ce.png)
7.定义一个接口
接口中有一个查询所有内容的方法,应为要查询所有内容
返回值是一个List集合
![](https://img-blog.csdnimg.cn/img_convert/41e878bf859a6c2db8c3edd796209c74.png)
8.编写Mapper.xml
在resources目录中下创建与接口对应的路径和对应名称的Mapper.xml文件
![](https://img-blog.csdnimg.cn/img_convert/87ce88059d8a37d32a5fa846e48e5cae.png)
9.要在在mybatis-config.xml中配置Mapper
![](https://img-blog.csdnimg.cn/img_convert/2d868611ca4a7f9e93b610742ec3bb92.png)
10.测试
![](https://img-blog.csdnimg.cn/img_convert/53e360728fd796097f747fedbf780f87.png)
测试结果
![](https://img-blog.csdnimg.cn/img_convert/cb098dad5ebb94ccf54eb82045519091.png)
总结:
1、读取 MyBatis 配置文件:mybatis-config.xml 为 MyBatis 的全局配置文件,配置了 MyBatis 的运行环境等信息,例如数据库连接信息。
2、加载映射文件。映射文件即 SQL 映射文件,该文件中配置了操作数据库的 SQL 语句,需要在 MyBatis 配置文件 mybatis-config.xml 中加载。mybatis-config.xml 文件可以加载多个映射文件,每个文件对应数据库中的一张表。
3、构造会话工厂:通过 MyBatis 的环境等配置信息构建会话工厂 SqlSessionFactory。
4、创建会话对象:由会话工厂创建 SqlSession 对象,该对象中包含了执行 SQL 语句的所有方法。
5、Executor 执行器:MyBatis 底层定义了一个 Executor 接口来操作数据库,它将根据 SqlSession 传递的参数动态地生成需要执行的 SQL 语句,同时负责查询缓存的维护。
6、MappedStatement 对象:在 Executor 接口的执行方法中有一个 MappedStatement 类型的参数,该参数是对映射信息的封装,用于存储要映射的 SQL 语句的 id、参数等信息。
7、输入参数映射:输入参数类型可以是 Map、List 等集合类型,也可以是基本数据类型和 POJO 类型。输入参数映射过程类似于 JDBC 对 preparedStatement 对象设置参数的过程。
8、输出结果映射:输出结果类型可以是 Map、 List 等集合类型,也可以是基本数据类型和 POJO 类型。输出结果映射过程类似于 JDBC 对结果集的解析过程。