1、MyBatis 是什么?
MyBatis 本是 Apache 的一个开源项目 iBatis, 2010 年这个项目由 Apache Software Foundation 迁移到了 Google Code,并且改名为 MyBatis,实质上 Mybatis 对 ibatis 进行一些改进。
MyBatis 是一个优秀的持久层框架,它对 JDBC 的操作数据库的过程进行封装,使开发者只需要关注 SQL 本身,而不需要花费精力去处理例如注册驱动、创建 Connection、创建 Statement、手动设置参数、结果集检索等 JDBC 繁杂的过程代码。
MyBatis 通过 xml 或注解的方式将要执行的各种 Statement(Statement、PreparedStatement、CallableStatement)配置起来,并通过 Java 对象和 Statement 中的 SQL 进行映射生成最终执行的 SQL 语句,最后由 MyBatis 框架执行 SQL 并将结果映射成 Java 对象并返回。
2、分析原生态 JDBC 程序中存在的问题
2.1、原生态 JDBC 程序代码
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
public class Test
{public static void main(String[] args)
{
Connection connection = null;
PreparedStatement preparedStatement = null;
ResultSet resultSet = null;
try
{
//1、加载数据库驱动
Class.forName("com.mysql.jdbc.Driver");
//2、通过驱动管理类获取数据库链接
connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/mybatis?characterEncoding=utf-8",
"root", "root");
//3、定义 sql 语句 ? 表示占位符
String sql = "select * from user where username = ?";
//4、获取预处理 statement
preparedStatement = connection.prepareStatement(sql);
//5、设置参数,第一个参数为 sql 语句中参数的序号(从 1 开始),第二个参数为设置的参数值
preparedStatement.setString(1, "admin");
//6、向数据库发出 sql 执行查询,查询出结果集
resultSet = preparedStatement.executeQuery();
//7、遍历查询结果集
while (resultSet.next())
{System.out.println(resultSet.getString("id") + "" + resultSet.getString("username"));
}
}
catch (Exception e)
{e.printStackTrace();
}
finally
{
//8、释放资源
if (resultSet != null)
{
try
{resultSet.close();
}
catch (SQLException e)
{e.printStackTrace();
}
}
if (preparedStatement != null)
{
try
{preparedStatement.close();
}
catch (SQLException e)
{e.printStackTrace();
}
}
if (connection != null)
{
try
{connection.close();
}
catch (SQLException e)
{e.printStackTrace();
}
}
}
}
}
2.2、JDBC 问题总结
(1)数据库连接频繁开启和关闭,会严重影响数据库的性能。
(2)代码中存在硬编码,分别是数据库部分的硬编码和 SQL 执行部分的硬编码。
3、MyBatis 框架原理
3.1、框架图
3.2、分析结论
(1)MyBatis 配置文件,包括 MyBatis 全局配置文件和 MyBatis 映射文件,其中全局配置文件配置了数据源、事务等信息;映射文件配置了 SQL 执行相关的信息。
(2)MyBatis 通过读取配置文件信息(全局配置文件和映射文件),构造出 SqlSessionFactory,即会话工厂。
(3)通过 SqlSessionFactory,可以创建 SqlSession 即会话。MyBatis 是通过 SqlSession 来操作数据库的。
(4)SqlSession 本身不能直接操作数据库,它是通过底层的 Executor 执行器接口来操作数据库的。
(5)Executor 接口有两个实现类,一个是普通执行器,一个是缓存执行器(默认)。Executor 执行器要处理的 SQL 信息是封装到一个底层对象 MappedStatement 中。该对象包括:SQL 语句、输入参数映射信息、输出结果集映射信息。其中输入参数和输出结果的映射类型包括 Java 的简单类型、HashMap 集合对象、POJO 对象类型。